26 / 2 / 0
Регистрация: 04.04.2012
Сообщений: 34
|
|
1 | |
Макрос для вставки макроса в Excel10.07.2012, 13:07. Показов 22300. Ответов 17
Метки нет Все метки)
(
Собственно, вопрос в названии. Можно ли написать макрос, который будет добавлять другой макрос в другой файл?
0
|
|
10.07.2012, 13:07 | |
Ответы с готовыми решениями:
17
Макрос для автоматической вставки фото в лист Excel Макрос вставки изображений в Excel Мне необходимо из макроса Excel запустить макрос Word.
|
1300 / 402 / 22
Регистрация: 21.10.2011
Сообщений: 1,285
|
||||||
10.07.2012, 13:37 | 2 | |||||
![]() Решение
Код по вставке модуля в активную книгу. В примере модуль находится на Рабочем столе и представляет из себя файл с расширением bas. Файл с модулем можно получить так:
5
|
здесь больше нет...
3372 / 1670 / 184
Регистрация: 03.02.2010
Сообщений: 1,219
|
||||||
10.07.2012, 13:49 | 3 | |||||
![]() Решение
1
|
![]() ![]() |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
11.07.2012, 03:10 | 4 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
![]() Решение
1. Экспорт модуля проекта в файл
2. Импорт модуля проекта из файла 3. Импорт модуля через организатор(данный код только для Word приложения) 4. Вставка новых строк в модуль проекта 5. Удаление строк из модуля 6. Чтение строк из модуля 7. Определение количества строк в модуле 8. Переименование модулей проекта 9. Удаление модулей проекта 10. Определение количества модулей в проекте 11. Создание нового модуля проекта Обработка модулей VBA программно
Под "ИмяПроекта" в программной конструкции подразумевается соответствующий объект. Для связи с книгой Excel предназначен объект - Workbooks("Имя книги"), а для связи с документом Word объект - Documents(“Имя документа”). Объект для связи с документом, который содержит общие макросы приложения Word, имеет имя: NormalTemplate, в Excel приложении данный объект записывается следующим образом: Workbooks("PERSONAL"). Экспорт модуля проекта в файл
№ - Номер строки в модуле с которой будут вставляться новые строки S – Вставляемая строка символов Примечание: В переменной S могут содержаться коды символов конца строк , которые можно получить следующей функцией со следующим аргументом: CHR(13). Таким образом, переменная S может содержать в себе сразу несколько строк:
№ - Номер строки в модуле с которой будут удаляться строки Количество – количество удаляемых строк Чтение строк из модуля
№ - Номер строки в модуле с которой будут начинаться чтение строк Количество – количество читаемых строк Определение количества строк в модуле
Смотрю кое-кому понравилось ![]() Много расширенных примеров есть на Cpearson При объявлении переменных будет ругаться на неизвестный тип данных: - подключаем Microsoft Visual Basic For Applications Extensibility library (Tools -> Preferences). Отсюда беруться и некоторые константы. Также потребуется открыть доверенный программный доступ к VBE:
2007-2010: 1) Файл -> Параметры -> Центр управления безопасностью -> Параметры центра управления безопасностью -> Доверять доступ к объектной модели проектов VBA. Альтернативно: 2а) Кнопка "Office" (файл) -> Параметры –> (меню "Основные" -> поле "Основные параметры работы с Excel") Настройка ленты -> галочка "Показывать вкладку "Разработчик" на ленте (в правом окне). 2б) Панель "Разработчик" -> группа "Код" -> Безопасность макросов -> меню "Параметры макросов" -> поле "Параметры макросов для разработчика" -> Доверять доступ к объектной модели проектов VBA. 2003: Сервис > Макрос > Безопасность... > Надежные издатели (вкладка) > Доверять досутуп к Visual Basic Project. Либо твик:
15
|
foo();
|
||||||
09.07.2013, 16:38 | 5 | |||||
Dragokas,
1
|
6875 / 2807 / 533
Регистрация: 19.10.2012
Сообщений: 8,559
|
||||||
09.07.2013, 16:43 | 6 | |||||
1
|
6875 / 2807 / 533
Регистрация: 19.10.2012
Сообщений: 8,559
|
|
09.07.2013, 17:04 | 8 |
![]() Решение
Ну конечно - это не просто, разделить ThisWorkbook.Path на Module1.bas, да ещё без остатка
![]()
3
|
11475 / 3767 / 676
Регистрация: 13.02.2009
Сообщений: 11,123
|
|
10.07.2013, 01:04 | 9 |
Angrynik,
Собственно ответ на вопрос: (никто до сих пор не ответил!) Да! Можно написать макрос, который будет добавлять другой макрос в другой файл Ещё есть вопросы?
0
|
0 / 0 / 0
Регистрация: 27.01.2014
Сообщений: 7
|
||||||
02.03.2014, 12:11 | 10 | |||||
Чтобы не плодить лишнего из-за простых вопросов, спрошу здесь.
Как проверить наличие модуля в шаблоне Normal.dot чтобы вернулось True или False Пробовал
0
|
3217 / 966 / 223
Регистрация: 29.05.2010
Сообщений: 2,085
|
||||||
02.03.2014, 12:27 | 11 | |||||
Попробуй проверить через возникновения ошибки:
1
|
0 / 0 / 0
Регистрация: 27.01.2014
Сообщений: 7
|
||||||
02.03.2014, 12:44 | 12 | |||||
Упс нашел,
0
|
11475 / 3767 / 676
Регистрация: 13.02.2009
Сообщений: 11,123
|
||||||
02.03.2014, 13:50 | 13 | |||||
0
|
0 / 0 / 0
Регистрация: 27.01.2014
Сообщений: 7
|
|
02.03.2014, 22:59 | 14 |
Как работает код toiai вроде понятно. Alex77755 объясните если не трудно, как работает функция и зачем вы объявляете переменные, тем более в коде я не увидел где она используется и зачем в 10 строке кода прописана единица.
0
|
11475 / 3767 / 676
Регистрация: 13.02.2009
Сообщений: 11,123
|
|
02.03.2014, 23:15 | 15 |
Option Explicit у меня то же всегда присутствует! Если вниметельно присмотрется, то в строке 8 всё-таки можно заметить намёк на использование переменной. А в 10 строке прописана 1 для того, что бы условный переход в строке 7 в случае ошибки "знал" куда переходить!
0
|
0 / 0 / 0
Регистрация: 27.01.2014
Сообщений: 7
|
||||||
02.03.2014, 23:37 | 16 | |||||
из танка плохо видно
![]()
0
|
11475 / 3767 / 676
Регистрация: 13.02.2009
Сообщений: 11,123
|
||||||
03.03.2014, 00:02 | 17 | |||||
У меня другая интерпритация:
0
|
0 / 0 / 0
Регистрация: 27.01.2014
Сообщений: 7
|
|
03.03.2014, 00:10 | 18 |
Вот спасибо
![]()
0
|
03.03.2014, 00:10 | |
Помогаю со студенческими работами здесь
18
Макрос для вставки символов юникода
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |