Многопоточность в VBA01.07.2023, 15:39. Показов 6251. Ответов 102
Метки multithreading in vba (Все метки)
Почему VBA? Про VB в принципе уже все давно расписано и исследовано за десятки лет. На VBA тема менее популярна, по в принципе понятным причинам, по скольку, там она не сильно так уж и нужна. Мне также в ней нет особой необходимости, просто некоторый интерес прощупать эту тему с точки зрения "простого обывателя", на сколько далеко можно зайти и т.д.
Вообще, говоря, на VBA есть довольно простая и удобная не очень изящная возможность организовать "потоки" за счет запуска нескольких копий приложения, также можно делать на VBS. Далее простой пример (в файле), назовем "Игра - Останови колобка если сможешь!" ). В примере все не очень оптимально, и нет какого-то полезного шаблона, но как мне кажется хорошо видно работу т.н. маршаллинга, его усточивую работу, даже при не очень, как бы правильной ситации. При запуске множества экземпляров Экселя и их одновременному обращению к одному и тому же объекту, все продолжает работать довольно устойчиво при том, что объектная модель отдельного Экселя "общается" со всеми в одном потоке или точнее из одного потока. Видимо маршаллинг все разруливает. В данном примере, не мало важно, что рабоает пропуск ошибок и doevents. Если попытаться реализовать подобное с помощью win-api то с этим уже появляются некоторые проблеммки.. и бог весть еще с чем, а вот при работе разных экземпляров Эксель все очень просто.
0
|
|
| 01.07.2023, 15:39 | |
|
Ответы с готовыми решениями:
102
VBA → SSMS → VBA. Вызов хранимой процедуры SSMS из VBA с возвратом 2ух и более параметров Программа в VBA для проверки гипотез про равенство средних - VBA VBA и Oracle: stored procedure из VBA и сохранение текста в переменной |
|
Испарился
1741 / 637 / 45
Регистрация: 10.09.2021
Сообщений: 2,769
|
|
| 01.07.2023, 20:24 | |
|
Ты разделом не ошибся? Есть специальный раздел для VBA именно.
0
|
|
|
|
|||
| 02.07.2023, 11:19 | |||
|
Я думаю что если нужна многопоточность, то имеет смысл перенести часть кода в dll написанную на ЯП с поддержкой многопоточности и в ней выполнять все что связано с потоками.
0
|
|||
|
Испарился
1741 / 637 / 45
Регистрация: 10.09.2021
Сообщений: 2,769
|
|
| 02.07.2023, 11:27 | |
|
Я вообще не понимаю зачем для VBA многопоточность. Но если что у The Trick'а есть много модулей и классов на эту тему.
0
|
|
| 02.07.2023, 15:05 [ТС] | ||||||
|
Добавлено через 5 минут
0
|
||||||
|
Испарился
1741 / 637 / 45
Регистрация: 10.09.2021
Сообщений: 2,769
|
||
| 02.07.2023, 15:09 | ||
|
0
|
||
|
Испарился
1741 / 637 / 45
Регистрация: 10.09.2021
Сообщений: 2,769
|
||
| 03.07.2023, 12:43 | ||
|
0
|
||
| 03.07.2023, 17:37 [ТС] | ||
|
Итак, чтож, пару выпущено много, пришло время и реальных дел! Многопоточный переводчик есть. Сейчас подготовлю вылжу файл и код.
Добавлено через 3 часа 28 минут
0
|
||
| 03.07.2023, 18:15 [ТС] | |
|
Короче вот эта адова хрень. То работатет то не работает только в 32бит. офисе. Случайно поймал момент когда она работатет и даже записал видео. Объекте HTMLDocument, для работы которого запускается отдельный процесс (типа WMI), добавляет немало глючности, может быть, что-то еще. Больше всего удрючает, что то что стабильно работало, может внезапно отказать, и вылезти неведомый и не понятный глюк.
0
|
|
| 03.07.2023, 18:26 [ТС] | |||||||||||
|
Код (стандартный модуль)
Кликните здесь для просмотра всего текста
Модуль переводчика. Кликните здесь для просмотра всего текста
Добавлено через 5 минут Забыл добавить описание, там должен текст переводится на два языка одновременно в 2 потоках - в этом весь смысл примера.
0
|
|||||||||||
|
Испарился
1741 / 637 / 45
Регистрация: 10.09.2021
Сообщений: 2,769
|
|
| 03.07.2023, 20:45 | |
|
Ну с потоками это всегда очень сложно. Подробно описано и без глюков это только у The Trick'а!
Добавлено через 1 минуту testuser2, Я к сожалению, не имею возможности запустить твой код и проверить так как у меня старая версия офиса. Там не поддерживает LongPtr даже.
0
|
|
| 03.07.2023, 20:54 | |
|
0
|
|
|
Испарился
1741 / 637 / 45
Регистрация: 10.09.2021
Сообщений: 2,769
|
|
| 03.07.2023, 21:07 | |
|
locm, можно и без DLL спокойно делать многопоточность. The Trick уже так делал, здесь на этом форуме есть примеры.
0
|
|
| 04.07.2023, 07:34 [ТС] | |||||||
|
Заметил один нюанс. Если вносишь какие-то правки в код то он перестает работать. А если выполнить рекомпиляцию (Debug->CompileVBAProject или запустить какую-нибудь процедуру-пустышку) и после этого перезагрузить документ с сохранением, все работает нормально. В этом заложен ящик Пандоры - когда ты пытаешься исправить причину, но все время создаешь ее по новой. Если вносишь правки, нужно обязательно рекомпилировать и перезапусить док. Не знаю что там происходит при перезапуске дока, но факт, что работает только так. Также, ели скопировал файл, обязательно произойдет ошибка, но при следующем запуске начнет работать, потому, что произодет божественная "рекомпиляция" Добавил кнопку со следующим кодом.
0
|
|||||||
| 04.07.2023, 11:50 [ТС] | |||||||
|
А многопоточки-то и нету. Отрабатывает один следом другой. И все жутко не стабильно. Трик зря не скажет. Выше-описанные меры - мертвому припарка.
Добавлено через 6 минут
0
|
|||||||
|
Испарился
1741 / 637 / 45
Регистрация: 10.09.2021
Сообщений: 2,769
|
|
| 04.07.2023, 13:50 | |
|
0
|
|
| 04.07.2023, 13:50 | |
|
Помогаю со студенческими работами здесь
20
VBA-проект для создания эл. сообщения в MS Outlook из-под любого VBA-приложения. VBA AutoCad - как снять (изменить) ограничение времени выполнения VBA Макроса? VBA SDK. Как включить в проект на VBA конструкторы? Купил книгу По VBA Программирование на VBA 2003 В.Г.Кузьменко Как получить ссылку на VBA-объект Application в DLL, которая привязана к этому VBA-приложению Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/
O1rJuneU_ls
https:/ / vkvideo. ru/ video-115721503_456239114
|
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ВВЕДЕНИЕ
Введу сокращения:
аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
|
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi
ветка по-частям.
коммит Create переделка под биомассу. txt
вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
|
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ *
Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях.
Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её.
Последовательность действий:. . .
|
|
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
|
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение.
И на уровне агентов добавится между грибами или бактериями взаимодействий.
До того я пробовал подход через многомерные массивы,. . .
|
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Налог на собак: https:/ / **********/ gallery/ V06K53e
Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf
Пост отсюда. . .
|
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop?
Ниже её машинный перевод.
После долгих разбирательств я наконец-то вернула себе. . .
|