|
|
Регистрация Восстановить пароль |
Регистрация | Задать вопрос |
Заплачу за решение |
Новые сообщения |
Сообщения за день |
Расширенный поиск |
Правила |
Всё прочитано |
|
Опции темы | Поиск в этой теме |
11.02.2022, 11:59 | #1 |
Пользователь
Регистрация: 02.07.2019
Сообщений: 25
|
обращение к Userform из другого макроса
Добрый день!
Подскажите, пожалуйста, по следующему вопросу. При запуске макроса открывается Userform в режиме vbModeless. В этом Userform отражается ход выполнения макроса (какие операции уже сделаны, какие выполняются сейчас и какие предстоит выполнить дальше). По завершению макроса данный Userform закрывается. В ходе выполнения макроса запускается другой макрос (через Application.run). Вопрос: как из этого второго макроса внести информацию о ходе его выполнения в вышеуказанную Userform? Облазил интернет, не нашёл ответа. Буду очень благодарен за помощь. |
11.02.2022, 12:28 | #2 |
2 the Nation Glory
Старожил
Регистрация: 27.05.2014
Сообщений: 3,289
|
как реализован ход выполнения первого макроса, может второй по аналогии сделать получится?
Кто умер, но не забыт, тот бессмертен.
Лао-Цзы. |
11.02.2022, 12:44 | #3 |
Пользователь
Регистрация: 02.07.2019
Сообщений: 25
|
Aleksandr H., Да, есть, конечно, вариант: закрыть userform в первом макросе - открыть во втором (с заполнением всех label, которые были заполнены в первом макросе) - по завершении второго макроса закрыть этот userform - по возвращению в первый макрос открыть снова данный userform с label, заполненными до запуска второго макроса и во время работы этого макроса.
Такой вариант срабатывает хорошо, в-принципе, но довольно муторный - label в userform довольно много и запусков других макросов из первого тоже много (пришлось дробить модуль на несколько модулей, поскольку в одном всё не уместилось). И постоянно по всему модулю "волочить" открытие-закрытие userform со всеми заполненными label немножко напрягает. Думал, может, есть какой-нибудь вариант, чтобы всё-таки не закрывать userform и чтобы он отработал по всем макросам, запускаемым из одного, главного, макроса. Последний раз редактировалось aie.fineff; 11.02.2022 в 12:48. |
11.02.2022, 12:54 | #4 |
Пользователь
Регистрация: 02.07.2019
Сообщений: 25
|
Активация userform в первом, главном, макросе, производится у меня так:
Userform.Show vbModeless DoEvents Потом по ходу его выполнения заполняются label, например: Userform.Label1.Caption = "Готово" Userform.Repaint Как я понимаю, чтобы этот Userform подкрепить к второму макросу надо вначале этого макроса вместо указанного метода .Show vbModeless что-то другое прописать. А вот что - не понятно. |
11.02.2022, 13:14 | #5 | |
2 the Nation Glory
Старожил
Регистрация: 27.05.2014
Сообщений: 3,289
|
Цитата:
Код:
Кто умер, но не забыт, тот бессмертен.
Лао-Цзы. |
|
11.02.2022, 14:00 | #6 |
Пользователь
Регистрация: 02.07.2019
Сообщений: 25
|
|
11.02.2022, 17:01 | #7 |
Новичок
СтарожилДжуниор
Регистрация: 05.02.2008
Сообщений: 9,487
|
нужен файл и указание на ту строку в другом макросе где вы хотите обратиться к форме, иначе - это гадания (вдруг кто-то случайно угадает ответ)
Программисты - это люди, решающие проблемы, о существовании которых Вы не подозревали, методами, которых Вы не понимаете
|
Похожие темы | ||||
Тема | Автор | Раздел | Ответов | Последнее сообщение |
Обращение к форме из другого потока | Antony41 | C# (си шарп) | 1 | 19.04.2021 08:18 |
обращение к элементу формы из другого файла | temik612 | Общие вопросы C/C++ | 2 | 17.03.2013 20:50 |
Вызов макроса внутри другого макроса. | Небесный | Microsoft Office Word | 1 | 05.11.2012 22:38 |
Как ComboBox на UserForm заполнить данными с другого листа ? | Snekich | Microsoft Office Excel | 2 | 08.12.2011 18:37 |
Запуск макроса с параметрами из другого макроса | Saladin | Microsoft Office Excel | 2 | 19.01.2009 09:43 |