vba excel имена диапазона как переменная

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

Добрый день, уважаемые. Вводная: на листе Excel есть однотипные имена типа ("P1B1"), ("P1B2"), ("P1B3"), ("P1B4"), ...., ("P1Bn"), а также ("P1С1"), ("P1С2"), ("P1С3"), ("P1С4"), ...., ("P1Сn"). Вопрос: как можно через цикл обращаться поочереди к именам ("P1B1"), ("P1B2"), ("P1B3"), ("P1B4"), ...., ("P1Bn"), не трогая имена ("P1С1"), ("P1С2"), ("P1С3"), ("P1С4"), ...., ("P1Сn"). Проблема: не могу пройти через цикл, так как имя диапазона типа "P1B" & i из цикла For i=1 to 10 не распознается в vba. Буду признателен за помощь.

Примечание:
Спасибо! Но, пока не получилось (((. По вопросу дополнение такое - на листе Excel именами типа ("P1B1"), ("P1B2"), ("P1B3"), ("P1B4"), ...., ("P1Bn") обозначены ячейки в произвольном/неизвестном порядке. Они используюися как якоря для нахождения позиции и вставки значений. Причина использования имен - меняющиеся значения строка/столбец. Использование цикла предполагалось как раз для обработки этих позиций/вставки значений. Поэтому код типа < "A1:B" & i > по определению не подходит. Код типа < If Left(n.Name, 3) = "P1B" Then Debug.Print n.Name> также не совсем подходит так как есть необходимость адресного обращения к определенным ячейкам. Интересует синтаксис обращения типа < Range("P1B" & i).Select > - принашу извинение если написал не правильно. Спасибо!

For i = 1 To 10
RangeName = "A1:B" & i
iCount = Range(RangeName).Count 'количество ячеек в диапазоне RangeName
Next i
Ответы:
Sub test()
   For Each n In ThisWorkbook.Names
       If Left(n.Name, 3) = "P1B" Then Debug.Print n.Name
   Next
End Sub
Лучше кусок кода показали бы.
Имена диапазонов A1:B1, A1:B2 и тд. Перед двоеточием верхняя левая ячейка, а после правая нижняя.
For i = 1 To 10
RangeName = "A1:B" & i
iCount = Range(RangeName).Count 'количество ячеек в диапазоне RangeName
Next i
Используй cells вместо Range, указывая не имя строки и столбца, а номер.


13 лет назад

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

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

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