Мне просто нужно активировать определенный лист. У меня есть строковая переменная, которая сохраняет имя рабочего листа.
Как активировать конкретный рабочий лист в Excel?
Ответ 1
Помогла бы вам следующая макроса?
Sub activateSheet(sheetname As String)
'activates sheet of specific name
Worksheets(sheetname).Activate
End Sub
В основном вы хотите использовать функцию .Activate. Или вы можете использовать функцию .Select следующим образом:
Sub activateSheet(sheetname As String)
'selects sheet of specific name
Sheets(sheetname).Select
End Sub
Ответ 2
Я бы рекомендовал вам использовать индекс рабочего листа вместо использования имени рабочего листа, таким образом, вы можете также циклически прокладывать листы "динамически"
for i=1 to thisworkbook.sheets.count
sheets(i).activate
'You can add more code
with activesheet
'Code...
end with
next i
Это также улучшит производительность.
Ответ 3
Альтернативный способ (не динамически) связывать текст, чтобы активировать рабочий лист без макросов, - сделать выбранную строку фактической ссылкой. Вы можете сделать это, выбрав ячейку, которая содержит текст, и нажмите CTRL + K, затем выберите опцию/вкладку "Место в этом документе" и выберите вкладку, которую вы хотите активировать. Если вы нажмете на текст (теперь это ссылка), настроенный лист станет активным/выбранным.