как в VBA вырезать символы из строки

Компьютеры программирование программы VBA

есть строка:
blabla[123456]blabla
как достать из нее все что между [ ]
там могут быть любые символы
Ответы:
Примерно так
strX = "blabla[123456]blabla" ' Это наша строка
intPoz1 = InStr(1, strX, "[", vbTextCompare) ' ищем в строке "[", начиная с 1 символа. intPoz1 = 7
intPoz2 = InStr(intPoz1+1, strX, "]", vbTextCompare) ' ищем в строке "]", начиная с 1 символа после "[". intPoz2 = 14
strY = Mid(strX, intPoz1+1, intPoz2 - intPoz1 - 1) ' Это результат - кусок строки, начиная с 1 символа после "[" и количество символов, равное разности между найденными числами. то есть 6 знаков, начиная от 7.
Можно применить регулярные выражения.
Sub Macros()
stroka = "blabla[123456]blabla"
Set objRegExp = CreateObject("VBScript.RegExp")
objRegExp.Pattern = ".*\["
stroka = objRegExp.Replace(stroka, "")
objRegExp.Pattern = "\].*"
stroka = objRegExp.Replace(stroka, "")
End Sub


13 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.