|
Айлурофил
|
|||||||||||
Запуск макроса VBA из внешней программы01.02.2025, 23:00. Показов 3502. Ответов 34
Метки нет (Все метки)
Win10
Создаю макрос в личной книге макросов, он создаётся здесь: C:\Users\Username\Appdata\Roaming\Micros oft\Excel\XLSTART\PERSONAL.XLSB Сам макрос:
C:\Laz-aep\xlsm\dummy.xlsm Из программы на Lazarus открываю таблицу и вызываю макрос на выполнение:
Если же его там нет, то выходит ошибка. Почему так?
0
|
|||||||||||
| 01.02.2025, 23:00 | |
|
Ответы с готовыми решениями:
34
Автоматический запуск макроса - VBA Запуск макроса в открытом документе из vba Запуск внешней программы программы из коммнадной строки |
|
Айлурофил
|
|
| 02.02.2025, 19:48 [ТС] | |
|
***
0
|
|
|
Айлурофил
|
||||||||||||||||
| 02.02.2025, 23:10 [ТС] | ||||||||||||||||
|
Попробовал хранить макрос в отдельной файле:
Далее макрос выполняет работу и закрывает macro.xlsm Проверил вручную - всё работает, но при запуске макроса из программы
0
|
||||||||||||||||
| 03.02.2025, 02:03 | ||||||||
|
Добавлено через 12 минут
0
|
||||||||
|
Айлурофил
|
|||||||||||
| 03.02.2025, 02:59 [ТС] | |||||||||||
|
Вроде бы, получилось.
Lazarus
0
|
|||||||||||
|
2062 / 491 / 134
Регистрация: 13.11.2008
Сообщений: 935
|
||||||
| 03.02.2025, 10:04 | ||||||
Сообщение было отмечено andris2 как решение
Решение
Изначально у Вас ничего не получалось, потому что при запуске Excel через CreateObject он запускается БЕЗ запуска стандартных надстроек и без личной книги макросов PERSONAL. Т.е. эти книги ЗАКРЫТЫ. И когда Вы пытаетесь вызвать Ex.Run('PERSONAL.XLSB!Macro') - то PERSONAL еще закрыт. Его надо открыть принудительно ДО того, как запускать макрос. Т.е. Вам в любом случае надо было сначала открыть PERSONAL из той папки, где он расположен, а не сразу пытаться к нему обратиться:
3
|
||||||
|
509 / 163 / 22
Регистрация: 04.10.2015
Сообщений: 646
|
|
| 03.02.2025, 11:29 | |
|
The_Prist,
Вот теперь все расставлено в нужной последовательности событий
0
|
|
| 03.02.2025, 13:26 | ||||||||
1
|
||||||||
|
Айлурофил
|
||
| 03.02.2025, 14:01 [ТС] | ||
|
С другой стороны, решение, найденное мной в #25, ничем не хуже, тем более, что файл с макросами может храниться в более удобном каталоге.
0
|
||
|
Айлурофил
|
|
| 06.02.2025, 01:50 [ТС] | |
|
К сожалению, возникла ещё одна проблема: я ошибочно полагал, что при выполнении Run запускается макрос, и, параллельно, программа на Lazarus продолжает свою работу. Увы, это не так, происходит "зависание" на этой строке, и, пока макрос не отработает, ничего не происходит. После выполнения макроса, управление передаётся дальше. Но у меня Lazarus и VBA должны организовать канал, через который обмениваются информацией (это уже отлажено и работает в среде LibreOffice).
То есть, нужны какие-то другие механизмы запуска макроса без ожидания. Что здесь можно посоветовать?
0
|
|
| 06.02.2025, 02:26 | |||||||||||||
Сообщение было отмечено Massaraksh7 как решение
РешениеПараметры:
Procedure - название процедуры (строка) Можно создать vba-процедуру и запускать ее.
1
|
|||||||||||||
|
Айлурофил
|
|
| 06.02.2025, 06:28 [ТС] | |
|
Спасибо, попробую.
Добавлено через 1 час 51 минуту Да, работает.
0
|
|
| 06.02.2025, 09:57 | |||
|
0
|
|||
|
2062 / 491 / 134
Регистрация: 13.11.2008
Сообщений: 935
|
||
| 06.02.2025, 10:28 | ||
0
|
||
| 06.02.2025, 10:33 | |
|
0
|
|
| 06.02.2025, 10:33 | |
|
Помогаю со студенческими работами здесь
35
Run-time error 1004. Запуск макроса excel в vba access Как установить пароль на запуск программы с макросом? Запуск внешнего приложения из макроса Запуск vba-скрипта из внешней среды в libreOffice Подключение с помощью макроса внешней прикладной программы в Access 2007 Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
[golang] Угол между стрелками часов
alhaos 12.05.2026
По заданным значениям часа и минуты необходимо определить значение меньшего угла между стрелками аналогового циферблата часов.
import "math"
func angleClock(hour int, minutes int) float64 {
. . .
|
Debian 13: Установка Lazarus QT5
ВитГо 09.05.2026
Эта инструкция моя компиляция инструкций volvo
https:/ / www. cyberforum. ru/ blogs/ 203668/ 10753. html
и его же старой инструкции по установке Lazarus с gtk2. . .
|
Нейросеть на алгоритме "эстафета хвоста" как перспектива.
Hrethgir 06.05.2026
На десерт, когда запущу сервер.
Статья тут https:/ / habr. com/ ru/ articles/ 1030914/ . Автор я сам, нейросеть только помогает в вопросах которые мне не известны - не знаю людей которые знали-бы. . .
|
Асинхронный приём данных из COM-порта
Argus19 01.05.2026
Асинхронный приём данных из COM-порта
Купил на aliexpress термопринтер QR701. Он оказался странным. Поключил к Arduino Nano. Был очень удивлён. Наотрез отказывается печатать русские буквы. Чтобы. . .
|
|
попытка написать игровой сервер на C++
pyirrlicht 29.04.2026
попытка написать игровой сервер на плюсах с открытым бесконечным миром.
возможно получится прикрутить интерпретатор питон для кастомизации игровой логики.
что есть на текущий момент:. . .
|
Контроль уникальности выбранного документа-основания при изменении реквизита
Maks 28.04.2026
Алгоритм из решения ниже разработан на примере нетипового документа "ЗаявкаНаРемонтСпецтехники", разработанного в КА2.
Задача: уведомлять пользователя, если указанная заявка (документ-основание). . .
|
Благородство как наказание
Maks 24.04.2026
У хорошего человека отношения с женщинами всегда складываются трудно. А я человек хороший. Заявляю без тени смущения, потому что гордиться тут нечем. От хорошего человека ждут соответствующего. . .
|
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2.
Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
|