Excel - как в VBA в параметре replacement собрать постоянный текст и значение переменной

программирование программы excel VBA

Sub replace()

Dim i As Long
For i = 1 To 3
Sheets(i).Select
Range("a1:e1").Select
Selection.replace What:="$2", Replacement:="$" + i, LookAt:=xlPart, _
SearchOrder:=xlByRows, MatchCase:=False, SearchFormat:=False, _
ReplaceFormat:=False
Next
End Sub

Мне надо на каждом листе найти все ячейки в заданном диапазоне, содержащие значение $2 и заменить это значение на значение "$номерлиста".

Комбинация Replacement:=i работает, а Replacement:="$" + i не работает. Как тут правильно это проделать?

И вдогонку - как сделать, чтобы заменялась не вся ячейка, а именно этот фрагмент содержимого ячейки?
Ну, если в ячейках формулы, содержащие это самое $2, а мне хочется заменить его в формулах на другие варианты, не трогая остальную часть формул...

Можно послать в толковый мануал.

Спасибо.

Примечание:
Попробовал вариант Replacement:="$" & i - вообще получил в ячейке "1р." !!!
Кошмар какой-то...

Примечание:
Оно, видимо, заменяет то, что было в ячейке, на $1, но тут же автоматически форматирует ячейку как валюту и превращает в рубли...

Надо заменять не всю ячейку, а только этот текст в формуле. Как?
Ответы:
Replacement:="$" + CStr(i)
Если у вас в книге три листа при Range("a1:e1").Select в первом цикле будет ошибка, так как получится циклическая ссылка.
При трех листах диапазон должен быть дальше третей строки


11 лет назад

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

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

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