Многопоточность в VBA01.07.2023, 15:39. Показов 6628. Ответов 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-приложению Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога
Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip
На первой гифке отладочные линии отключены, а на второй включены:. . .
|
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога
Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip
https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&d=1772460536
Одним из. . .
|
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
|
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
|
|
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
|
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога
Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
|
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование
. \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json>
Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом.
# Check if. . .
|
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так:
https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347
Основана на STM32F303RBT6.
На борту пять. . .
|