![]() |
|
|
#1
|
|||
|
|||
![]() работаю с Excel, открываю приложение, открываю книгу(указывая путьк файлу), осталось сделать активным нужный мне лист, но не получается... Нашел процедурку на форуме -
Код:
procedure ActivateWorkSheet(WorkBookName, WorkSheetName: Ansistring); var k, j: integer; begin if VarIsEmpty(E) = false then begin k := E.WorkBookIndex(WorkBookName); j := E.WorkSheetIndex(WorkBookName, WorkSheetName); if j <> 0 then E.WorkBooks[k].Sheets[j].Activate; end; end; Как можно указывая имя листа, например 'Labels' сделать его активным?? |
#2
|
|||
|
|||
![]() Включи запись макросов в экселе, сделай то, что нужно и посмотри код макроса. Там будут все необходимые команды. тол ко иногда приходится делать это через одно место, что бы потом нормально делалось из программы (т.е. с выделением нужного листа надо сделать это через поиск, например).
Почему не даю пример кода - что бы потом с подобными вопросами сам мог разобраться. |
#3
|
|||
|
|||
![]() Так то понятно, как макросы обращаются к листм, но в
E.WorkBooks[1].Sheets[1].Select; - В Delphi работает E.WorkBooks[1].Sheets('Labels').Select; - а это нет - Пишет ошибку - "Не найден член группы" ??? Хотя именно так идет активация листа в в VBA , т.е. Sheets('Labels').Select; |