Содержание
- Excel узнать имя кнопки
- Как я могу просмотреть свойства кнопки на листе Excel?
- 4 ответа 4
- Как посмотреть какой макрос назначен кнопке
- Как посмотреть какой макрос назначен кнопке
- Добавление кнопки (управление формы)
- Добавление кнопки (ActiveX управления)
- Добавление кнопки (управление формы)
- Добавление кнопки (Visual Basic управления)
- Дополнительные сведения
- Как узнать, какой макрос привязан к кнопке на вкладке приложения?
- 2 Ответ от Alex_Gur 02.09.2015 09:44:10
- Сообщений [ 2 ]
- Похожие темы
- Как записать макрос в Excel? Пошаговая инструкция.
- Отображение вкладки «Разработчик» в ленте меню
- Запись макроса в Excel
- Что записывает макрос?
- Абсолютная и относительная запись макроса
- Что нельзя сделать с помощью макрорекодера?
- Расширение файлов Excel, которые содержат макросы
Excel узнать имя кнопки
Вот варианты попроще:
И пример файла (с 3 разными типами кнопок):
Спасибо, попробовал второй вариант — сработало.
Правда, после замены Me. на ActiveSheet.
Что зачит это Me?
И еще, почему в Вашем файле нет модулей, а пример работает?
P.S. «Благодарности принимаются . » — можно подробности в личку?
Me — это ссылка на объект, в модуле которого расположен код.
В данном случае, код расположен в модуле листа — поэтому Me ссылается на лист, на котором расположены кнопки.
почему в Вашем файле нет модулей, а пример работает?
Разница между Me и activesheet: набрав Me в модуле листа, и нажав точку, получаем выпадающий список методов для объекта типа Worksheet — это облегчает (ускоряет) набор кода.
После набора activesheet и точки, к сожалению, выпадающий список свойств и методов не появляется (недоработка Microsoft)
Разницы при использовании различных модулей для обычных макросов, вызываемых кнопкой на листе, нет.
Модули листов и книги обычно используются для обработчиков событий соответствующих объектов — например, чтобы отловить изменение ячейки, открытие книги, активацию листа, и т.п.
В стандартных модулях обычно помещают код, который должен быть доступен из других мест — к примеру, пользовательские функции, которые должны работать на всех листах.
Источник
Как я могу просмотреть свойства кнопки на листе Excel?
У меня есть документ Excel, который мне нужно изменить. Эта вещь была создана «гуру» и была закрыта практически от любой формы модификации.
У меня есть мастер-пароль для доступа к модулям VBA, и, я полагаю, это все, что мне нужно для внесения любых изменений в рабочие листы этого документа.
Первый лист этого файла Excel — это доска переключателей. Он имеет ряд кнопок, которые запускают различные формы VBA, которые используются для ввода данных. Мне нужно изменить свойства, связанные с одной из этих кнопок, но я не могу понять, как просматривать диалог свойств. Как я могу отобразить это?
К вашему сведению, я много раз пытался щелкнуть правой кнопкой мыши по этой кнопке, но не могу открыть контекстное меню. Что я могу сделать, чтобы изменить эту кнопку?
4 ответа 4
Щелкните правой кнопкой мыши любой элемент управления и выберите Свойства
Тогда у вас есть джокер, который не использовал элементы управления, а использовал текстовые поля. И не только текстовые поля, но и сгруппированные текстовые поля. В этом случае вы можете войти в режим разработки, как описано выше, и при нажатии правой кнопкой мыши на текстовом поле появится опция « Assign Macro макрос». Выбор этого открывает диалоговое окно, которое позволяет вам сделать новый макрос или записать его. Конечно, вы будете удивляться , как это работает , если нет макроса уже назначен на этот Shape. Да, Shape not Textbox, потому что Excel не любит слишком четко различать. Затем вы некоторое время будете возиться и пытаться воссоздать исходный объект без определенного макроса, чтобы он перестал запускать макрос каждый раз, когда вы пытаетесь щелкнуть по вложенному текстовому полю. Вам нужно будет кликать по вложенным текстовым полям, пока вы не получите тот, который вам нужен, чтобы отобразить его как выделенный (подсказка: попробуйте щелкнуть правой кнопкой мыши сам текст). Вы можете даже искать и узнавать, как разгруппировать текстовые поля (выделите текстовое поле, посмотрите на ленту, где написано «Инструменты рисования», а затем перейдите на вкладку «Формат»). Как только нужный объект выделен, контекстное меню должно показать уже назначенный ему макрос и предложить опцию «Редактировать». Теперь вы сможете приступить к отладке или изменению кода спагетти VBA, несомненно оставленного «гуру». Вы можете даже искать определение «гуру»: духовный учитель, особенно тот, кто передает посвящение. Считайте себя «инициированным».
Это немного старый пост, но я уверен, что у большего количества людей будет тот же самый вопрос.
Откройте вкладку « Разработчик » на ленте.
Нажмите Режим дизайна.
Щелкните правой кнопкой мыши по кнопке возле края (в противном случае она открывается с помощью « Переместить сюда», « Копировать сюда», « Отмена» ).
Выберите Управление форматом .
Откроется диалоговое окно с 7 вкладками, которое позволяет редактировать различные свойства.
Источник
Как посмотреть какой макрос назначен кнопке
Как посмотреть какой макрос назначен кнопке
Вы можете использовать кнопку управления формы или кнопку (ActiveX) для запуска макроса, который выполняет действие, когда пользователь щелкает его. Обе эти кнопки также называются push-кнопками, которые можно настроить для автоматизации печати, фильтрации данных или вычисления чисел. Как правило, кнопки управления формы и ActiveX похожи по внешнему виду и функции. Однако между ними есть несколько отличий, которые объясняются в следующих разделах.
Кнопка (управление формы)
В разделах ниже вы узнаете, как добавить макрос на кнопку в Excel для Windows или Mac.
Примечание: ActiveX не поддерживаются на компьютере Mac.
Макрос и средства VBA находятся на вкладке Разработчик, которая по умолчанию скрыта.
Прежде всего нужно включить его. Дополнительные сведения см. в статье Показ вкладки «Разработчик».
Добавление кнопки (управление формы)
На вкладке Разработчик в группе Элементы управления нажмите кнопку Вставить, а затем в группе Элементы управления формы нажмитекнопку .
Щелкните на листе место, где должен быть расположен левый верхний угол кнопки. Появится всплывающее окно Назначение макроса.
Назначьте кнопке макрос и нажмите кнопку ОК.
Чтобы задать свойства кнопки, щелкните ее правой кнопкой мыши и выберите форматирование.
Добавление кнопки (ActiveX управления)
На вкладке Разработчик в группе Элементы управления нажмите кнопку Вставить, а затем вгруппе Элементы управления ActiveX нажмите кнопку .
Щелкните на том месте, где должен отображаться левый верхний угол кнопки.
В группе Элементы управления нажмите кнопку Код представления. При этом Visual Basic редактора. Убедитесь, что в списке справа выбрано нажатие кнопки. При нажатии кнопки CommandButton1_Click процедуры (см. рисунок ниже) запускаются эти два макроса: SelectC15 и HelloMessage.
В подпроцеду для кнопки сделайте следующее:
Введите имя существующего макроса в книге. Макрос можно найти, щелкнув Макрос в группе Код. С помощью кнопки можно запускать несколько макроса, вводя их имена в отдельных строках подпроцесса.
При необходимости добавьте собственный код VBA.
Закроем Visual Basic редактора и нажмите кнопку Режим конструктора режим конструктора, чтобы отключить режим конструктора.
Чтобы запустить код VBA, который теперь является частью кнопки, нажмите кнопку ActiveX, которую вы только что создали.
Чтобы изменить элемент ActiveX, убедитесь, что выбран режим конструктора. На вкладке Разработчик в группе Элементы управления нажмите кнопку Режим конструктора.
Чтобы задать свойства кнопки, на вкладке Разработчик в группе Элементы управления нажмите кнопку Свойства . Можно также щелкнуть правой кнопкой мыши кнопку и щелкнуть свойства .
Примечание: Перед тем как нажать кнопку Свойства, выделите объект, свойства которого требуется просмотреть или изменить.
Появится поле Свойства. Для получения дополнительных сведений о каждом свойстве выберите свойство и нажмите клавишу F1, чтобы отобразить соответствующий раздел справка по Visual Basic. Можно также ввести имя свойства в поле Поиск справки Visual Basic. В следующей таблице 2010 2010 2016 2016 2016 2016 201
Загружает ли его при открытом книге. (Игнорируется для ActiveX элементов управления.)
Может ли он получать фокус и отвечать на события, созданные пользователем.
Можно ли изменять элемент управления
Имя элемента управления
Способ привязки элемента управления к расположенным под ним ячейкам (не закреплен, можно перемещать, но нельзя изменять размер, можно перемещать и изменять размер)
Можно ли выводить элемент управления на печать
Является ли элемент управления видимым или скрытым
Атрибуты шрифта (полужирный, курсив, размер, зачеркивание, подчеркивание и насыщенность)
Bold, Italic, Size, StrikeThrough, Underline, Weight (форма)
Поясняющий текст элемента управления, определяющий или описывающий его
Будет ли содержимое элемента управления переноситься по словам в конце строки
Размер и положение
Будет ли размер элемента управления изменяться автоматически для отображения всего содержимого
Высота или ширина в пунктах
Height, Width (форма)
Расстояние от элемента управления до левого или верхнего края листа
Стиль фона (прозрачный или непрозрачный)
Цвет переднего плана
Наличие тени элемента управления
Точечный рисунок, отображаемый в элементе управления
Положение рисунка относительно его заголовка (слева, сверху, справа и так далее)
Клавиатура и мышь
Сочетание клавиш для элемента управления
Настраиваемый значок мыши
Тип указателя, отображаемого при наведите указатель мыши на определенный объект (стандартный, стрелка, I-указатель и так далее).
Будет ли фокус при щелчке.
Макрос и средства VBA находятся на вкладке «Разработчик», которая по умолчанию скрыта, поэтому сначала нужно включить ее.
Перейдите в Excel > параметры. > ленты & панель инструментов.
В категории Настроить ленту в списке Основные вкладки установите флажок Разработчик, а затем нажмите кнопку Сохранить.
Добавление кнопки (управление формы)
На вкладке Разработчик нажмите кнопку .
Щелкните на листе место, где должен быть расположен левый верхний угол кнопки. Появится всплывающее окно Назначение макроса.
Примечание: Если кнопка уже вставлена, щелкните ее правой кнопкой мыши и выберите назначить макрос.
Назначьте кнопке макрос и нажмите кнопку ОК.
Чтобы задать свойства кнопки, щелкните ее правой кнопкой мыши и выберите форматирование.
Добавление кнопки (Visual Basic управления)
На вкладке Разработчик нажмите кнопку .
Щелкните место на том месте, где должен отображаться левый верхний угол кнопки.
Примечание: Если кнопка уже вставлена, щелкните ее правой кнопкой мыши и выберите назначить макрос.
В диалоговом окне Назначение макроса выберите Новый, который откроет редактор Visual Basic(VBE)в области со следующим кодом:
В подпроцеду для кнопки между строками Sub и End Sub сделайте следующее:
Введите имя существующего макроса в книге. Вы можете запускать несколько макроса с помощью кнопки, введя их имена в отдельных строках внутри под процедуры.
Добавьте собственный код VBA.
Нажмите кнопку Режим режим конструктора, чтобы режим конструктора отключен, а затем закроем Visual Basic редактора.
Чтобы изменить кнопку, щелкните ее правой кнопкой мыши ивыберите Visual Basic .
Чтобы задать свойства кнопки, щелкните ее правой кнопкой мыши и выберите форматирование.
Дополнительные сведения
Вы всегда можете задать вопрос специалисту Excel Tech Community или попросить помощи в сообществе Answers community.
Как узнать, какой макрос привязан к кнопке на вкладке приложения?
Уважаемые коллеги!
На вкладке Главная в пользовательской группе Новая группа имеется несколько пользовательских кнопок.
Как узнать, какие макросы привязаны к этим кнопкам?
2 Ответ от Alex_Gur 02.09.2015 09:44:10
- Alex_Gur
- Модератор
- Неактивен
- Откуда: Москва
- Зарегистрирован: 28.07.2011
- Сообщений: 2,758
- Поблагодарили: 492
Re: Как узнать, какой макрос привязан к кнопке на вкладке приложения?
Уважаемые коллеги!
Ответ на свой вопрос нашел сам:
Открываем вкладку Настройка ленты в Параметрах Word.
В правой части вкладки открываем пользовательскую группу, где находятся пользовательские кнопки и подводим курсор мыши к строке нужной кнопки (но не нажимаем на кнопку мыши).
Через небольшое время на экран выводится подсказка, в конце которой указан искомый макрос (см. рисунок в приложении).
Кнопка и макрос_а.JPG 109.02 Кб, файл не был скачан.
You don’t have the permssions to download the attachments of this post.
Сообщений [ 2 ]
Страницы 1
Чтобы отправить ответ, вы должны войти или зарегистрироваться
Похожие темы
Как узнать, какой макрос привязан к кнопке на вкладке приложения?
Если вы по роду своей деятельности работаете с документами, то вам очень часто приходится иметь дело с редактором текстов Microsoft Word. На портале о Microsoft Office Word вы узнаете про: как не ставить номер страниц в ворде 2007. Познакомиться с тонкостями работы в этой программе вы можете на форуме сайта Ворд Эксперт.
Здесь участники делятся друг с другом своими вариантами настроек и принципов форматирования и редактирования текстов. На портале о Microsoft Office Word вы узнаете про: рамки на тектсовом документе по гост. На форуме много внимания уделено написанию макросов, созданию шаблонов и другим способам автоматизировать работу Ворда. На портале о Microsoft Office Word вы узнаете про: заменить одно слово другим vba. Также можно найти информацию по различию в настройках версий программы.
В специальных подразделах возможно оставить заявки или позаимствовать готовые решения. Наш сайт о Microsoft Office Word даст ответ про: как переустановить основной шрифт.
Как записать макрос в Excel? Пошаговая инструкция.
Макрос — это код, написанный на встроенном в Excel языке VBA (Visual Basic for Application). Макросы могут создаваться как вручную, так и записываться автоматически с помощью так называемого макрорекодера.
Макрорекодер — это инструмент в Excel, который пошагово записывает все что вы выполняете в Excel и преобразует это в код на языке VBA. Макрорекодер создает очень подробный код (как мы увидим позже), который вы сможете при необходимости отредактировать в дальнейшем.
Записанный макрос можно будет запускать неограниченное количество раз и Excel повторит все записанные шаги. Это означает, что даже если вы ничего не знаете о VBA, вы можете автоматизировать некоторые задачи, просто записав свои шаги и затем повторно использовать их позже.
Теперь давайте погрузимся и посмотрим, как записать макрос в Excel.
Отображение вкладки «Разработчик» в ленте меню
Перед тем как записывать макрос, нужно добавить на ленту меню Excel вкладку «Разработчик». Для этого выполните следующие шаги:
- Щелкните правой кнопкой мыши по любой из существующих вкладок на ленте и нажмите «Настроить ленту». Он откроет диалоговое окно «Параметры Excel».
- В диалоговом окне «Параметры Excel» у вас будут параметры «Настроить ленту». Справа на панели «Основные вкладки» установите флажок «Разработчик».
- Нажмите «ОК».
В результате на ленте меню появится вкладка «Разработчик»
Запись макроса в Excel
Теперь давайте запишем очень простой макрос, который выбирает ячейку и вводит в нее текст, например «Excel».
Вот шаги для записи такого макроса:
- Перейдите на вкладку «Разработчик».
- В группе «Код» нажмите кнопку «Запись макроса». Откроется одноименное диалоговое окно.
- В диалоговом окне «Запись макроса» введите имя для своего макроса, например «ВводТекста». Есть несколько условий именования, которые необходимо соблюдать при назначении макроса. Например, вы не можете использовать пробелы между ними. Обычно я предпочитаю сохранять имена макросов как одно слово, с разными частями с заглавным первым алфавитом. Вы также можете использовать подчеркивание для разделения двух слов — например, «Ввод_текста».
- Если вы хотите, то можете задать сочетание клавиш. В этом случае мы будем использовать ярлык Ctrl + Shift + N. Помните, что сочетание, которое вы указываете, будет отменять любые существующие горячие клавиши в вашей книге. Например, если вы назначили сочетание Ctrl + S, вы не сможете использовать это для сохранения рабочей книги (вместо этого, каждый раз, когда вы его используете, он выполняет макрос).
- В поле «Сохранить в» убедитесь, что выбрана опция «Эта книга». Этот шаг гарантирует, что макрос является частью рабочей книги. Он будет там, когда вы сохраните его и снова откроете, или даже если вы поделитесь файлом с кем-то.
- Введите описание при необходимости. Обычно я этого не делаю, но если у вас много макросов, лучше указать, чтобы в будущем не забыть что делает макрос.
- Нажмите «ОК». Как только вы нажмете OK, Excel начнет записывать ваши действия. Вы можете увидеть кнопку «Остановить запись» на вкладке «Разработчик», которая указывает, что выполняется запить макроса.
- Выберите ячейку A2.
- Введите текст «Excel» (или вы можете использовать свое имя).
- Нажмите клавишу Enter. Вы попадете на ячейку A3.
- Нажмите кнопку «Остановить запись» на вкладке «Разработчик».
Поздравляем! Вы только что записали свой первый макрос в Excel. Хотя макрос не делает ничего полезного, но он поможет нам понять как работает макрорекордер в Excel.
Теперь давайте рассмотрим код который записал макрорекодер. Выполните следующие действия, чтобы открыть редактор кода:
- Удалите текст в ячейке A2. Это нужно, чтобы проверить будет ли макрос вставлять текст в ячейку A2 или нет.
- Выберите любую ячейку — кроме A2. Это нужно проверить, выбирает ли макрос ячейку A2 или нет.
- Перейдите на вкладку «Разработчик».
- В группе «Код» нажмите кнопку «Макросы».
- В диалоговом окне «Макрос» щелкните макрос «ВводТекста».
- Нажмите кнопку «Выполнить».
Вы увидите, что как только вы нажмете кнопку «Выполнить», текст «Excel» будет вставлен в ячейку A2 и выбрана ячейка A3. Это происходит за миллисекунды. Но на самом деле макрос последовательно выполнил записанные действия.
Примечание. Вы также можете запустить макрос с помощью сочетания клавиш Ctrl + Shift + N (удерживайте клавиши Ctrl и Shift, а затем нажмите клавишу N). Это тот же самый ярлык, который мы назначили макросу при его записи.
Что записывает макрос?
Теперь перейдем к редактору кода и посмотрим что у нас получилось.
Вот шаги по открытию редактора VB в Excel:
- Перейдите на вкладку «Разработчик».
- В группе «Код» нажмите кнопку «Visual Basic».
Вы также можете использовать комбинацию клавиш Alt + F11 и перейти в редактор кода VBA.
Рассмотрим сам редактор кода. Далее коротко опишем интерфейс редактора.
- Панель меню: содержит команды, которые можно использовать во время работы с редактором VB.
- Панель инструментов — похожа на панель быстрого доступа в Excel. Вы можете добавить к ней дополнительные инструменты, которыми часто пользуетесь.
- Окно проектов (Project Explorer) — здесь Excel перечисляет все книги и все объекты в каждой книге. Например, если у нас есть книга с 3 рабочими листами, она появится в Project Explorer. Здесь есть несколько дополнительных объектов, таких как модули, пользовательские формы и модули классов.
- Окно кода — собственно сам код VBA размещается в этом окне. Для каждого объекта, указанного в проводнике проекта, есть окно кода, например, рабочие листы, книги, модули и т. д. В этом уроке мы увидим, что записанный макрос находится в окне кода модуля.
- Окно свойств — вы можете увидеть свойства каждого объекта в этом окне. Я часто использую это окно для обозначения объектов или изменения их свойств.
- Immediate Window (окно предпросмотра) — На начальном этапе оно вам не пригодится. Оно полезно, когда вы хотите протестировать шаги или во время отладки. Он по умолчанию не отображается, и вы можете его отобразить, щелкнув вкладку «View» и выбрав опцию «Immediate Window».
Когда мы записали макрос «ВводТекста», в редакторе VB произошли следующие вещи:
- Был добавлен новый модуль.
- Макрос был записан с именем, которое мы указали — «ВводТекста»
- В окне кода добавлена новая процедура.
Поэтому, если вы дважды щелкните по модулю (в нашем случае модуль 1), появится окно кода, как показано ниже.
Вот код, который записан макрорекодером:
В VBA, любая строка , которая следует за ‘ (знак апострофа) не выполняется. Это комментарий, который предназначен только для информационных целей. Если вы удалите первые пять строк этого кода, макрос по-прежнему будет работать.
Теперь давайте пробежим по каждой строке кода и опишем что и зачем.
Код начинается с Sub, за которым следует имя макроса и пустые круглые скобки. Sub — сокращение для подпрограммы. Каждая подпрограмма (также называемая процедурой) в VBA начинается с Sub и заканчивается End Sub.
- Range(«A2»).Select — эта строка выбирает ячейку A2.
- ActiveCell.FormulaR1C1 = «Excel» — эта строка вводит текст «Excel» в активной ячейке. Поскольку мы выбрали ячейку A2 в качестве первого шага, она становится нашей активной ячейкой.
- Range(«A3»).Select — выбор ячейки A3. Это происходит, когда мы нажимаем клавишу Enter после ввода текста, результатом которого является выбор ячейки A3.
Надеюсь, что у вас есть некоторое базовое понимание того, как записывать макрос в Excel.
Обращаем внимание, что код, записанный через макрорекордер, как правило, не является эффективным и оптимизированным кодом. Макрорекордер часто добавляет дополнительные ненужные действия. Но это не значит, что не нужно пользоваться макрорекодером. Для тех, кто только изучает VBA , макрорекордер может быть отличным способом проанализировать и понять как все работает в VBA.
Абсолютная и относительная запись макроса
Вы уже знаете про абсолютные и относительные ссылки в Excel? Если вы используете абсолютную ссылку для записи макроса, код VBA всегда будет ссылаться на те же ячейки, которые вы использовали. Например, если вы выберете ячейку A2 и введете текст «Excel», то каждый раз — независимо от того, где вы находитесь на листе и независимо от того, какая ячейка выбрана, ваш код будет вводить текст «Excel» в ячейку A2.
Если вы используете параметр относительной ссылки для записи макроса, VBA не будет привязываться к конкретному адресу ячейки. В этом случае программа будет «двигаться» относительно активной ячейки. Например, предположим, что вы уже выбрали ячейку A1, и вы начинаете запись макроса в режиме относительной ссылки. Теперь вы выбираете ячейку A2, вводите текст Excel и нажмите клавишу Enter. Теперь, если вы запустите этот макрос, он не вернется в ячейку A2, вместо этого он будет перемещаться относительно активной ячейки. Например, если выбрана ячейка B3, она переместится на B4, запишет текст «Excel» и затем перейдет к ячейке K5.
Теперь давайте запишем макрос в режиме относительных ссылок:
- Выберите ячейку A1.
- Перейдите на вкладку «Разработчик».
- В группе «Код» нажмите кнопку «Относительные ссылки». Он будет подсвечиваться, указывая, что он включен.
- Нажмите кнопку «Запись макроса».
- В диалоговом окне «Запись макроса» введите имя для своего макроса. Например, имя «ОтносительныеСсылки».
- В опции «Сохранить в» выберите «Эта книга».
- Нажмите «ОК».
- Выберите ячейку A2.
- Введите текст «Excel» (или другой как вам нравится).
- Нажмите клавишу Enter. Курсор переместиться в ячейку A3.
- Нажмите кнопку «Остановить запись» на вкладке «Разработчик».
Макрос в режиме относительных ссылок будет сохранен.
Теперь сделайте следующее.
- Выберите любую ячейку (кроме A1).
- Перейдите на вкладку «Разработчик».
- В группе «Код» нажмите кнопку «Макросы».
- В диалоговом окне «Макрос» кликните на сохраненный макрос «ОтносительныеСсылки».
- Нажмите кнопку «Выполнить».
Как вы заметите, макрос записал текст «Excel» не в ячейки A2. Это произошло, потому что вы записали макрос в режиме относительной ссылки. Таким образом, курсор перемещается относительно активной ячейки. Например, если вы сделаете это, когда выбрана ячейка B3, она войдет в текст Excel — ячейка B4 и в конечном итоге выберет ячейку B5.
Вот код, который записал макрорекодер:
Обратите внимание, что в коде нет ссылок на ячейки B3 или B4. Макрос использует Activecell для ссылки на текущую ячейку и смещение относительно этой ячейки.
Не обращайте внимание на часть кода Range(«A1»). Это один из тех случаев, когда макрорекодер добавляет ненужный код, который не имеет никакой цели и может быть удален. Без него код будет работать отлично.
Что нельзя сделать с помощью макрорекодера?
Макро-рекордер отлично подходит для вас в Excel и записывает ваши точные шаги, но может вам не подойти, когда вам нужно сделать что-то большее.
- Вы не можете выполнить код без выбора объекта. Например, если вы хотите, чтобы макрос перешел на следующий рабочий лист и выделил все заполненные ячейки в столбце A, не выходя из текущей рабочей таблицы, макрорекодер не сможет этого сделать. В таких случаях вам нужно вручную редактировать код.
- Вы не можете создать пользовательскую функцию с помощью макрорекордера. С помощью VBA вы можете создавать пользовательские функции, которые можно использовать на рабочем листе в качестве обычных функций.
- Вы не можете создавать циклы с помощью макрорекордера. Но можете записать одно действие, а цикл добавить вручную в редакторе кода.
- Вы не можете анализировать условия: вы можете проверить условия в коде с помощью макрорекордера. Если вы пишете код VBA вручную, вы можете использовать операторы IF Then Else для анализа условия и запуска кода, если true (или другой код, если false).
Расширение файлов Excel, которые содержат макросы
Когда вы записываете макрос или вручную записываете код VBA в Excel, вам необходимо сохранить файл с расширением файла с поддержкой макросов (.xlsm).
До Excel 2007 был достаточен один формат файла — .xls. Но с 2007 года .xlsx был представлен как стандартное расширение файла. Файлы, сохраненные как .xlsx, не могут содержать в себе макрос. Поэтому, если у вас есть файл с расширением .xlsx, и вы записываете / записываете макрос и сохраняете его, он будет предупреждать вас о сохранении его в формате с поддержкой макросов и покажет вам следующее диалоговое окно:
Если вы выберете «Нет», Excel сохранить файл в формате с поддержкой макросов. Но если вы нажмете «Да», Excel автоматически удалит весь код из вашей книги и сохранит файл как книгу в формате .xlsx. Поэтому, если в вашей книге есть макрос, вам нужно сохранить его в формате .xlsm, чтобы сохранить этот макрос.
Источник
KOT Пользователь Сообщений: 68 |
В книге несколько макросов, на листе несколько кнопок. Кнопки из меню «Формы». Есть ли возможность узнать какая кнопка за что отвечает? Искал поиском на форуме и не нашел. |
а просто потыкать? но вообще у кнопок есть свойство onaction.. |
|
Зависит от кнопок. слэн, просто «потыкать» мне, лично, не нравится. Я предпочитаю сначала прочитать код, а потом запускать, уже понимая, что он должен делать |
|
KOT Пользователь Сообщений: 68 |
Правая кнопка помогла. Я и раньше ей пользовался для назначения макроса, но не обращал внимания что в верхнем окне указывается КАКОЙ макрос ей УЖЕ назначен. Спасибо. |
{quote}{login=Лузер™}{date=10.07.2008 12:35}{thema=}{post}Зависит от кнопок. слэн, просто «потыкать» мне, лично, не нравится. Я предпочитаю сначала прочитать код, а потом запускать, уже понимая, что он должен делать{/post}{/quote} да, я сам часто страдаю от моего подхода, но перебороть себя не могу :)) |
|
{quote}{login=}{date=10.07.2008 12:53}{thema=Re: }{post}{quote}{login=Лузер™}{date=10.07.2008 12:35}{thema=}{post}Зависит от кнопок. слэн, просто «потыкать» мне, лично, не нравится. Я предпочитаю сначала прочитать код, а потом запускать, уже понимая, что он должен делать{/post}{/quote} да, я сам часто страдаю от моего подхода, но перебороть себя не могу :)){/post}{/quote}Кнопкозависимость? |
|
Igor67 Пользователь Сообщений: 3729 |
А может черта характера — действие опережает мысль, или просто сила привычки Есть кнопка — надо нажать… |
русский менталитет — сначала сделать, а потом думать. вот вы покупая что-нибудь из техники (телевизор, двд, камеру), сначала читаете инструкцию или сначала все-таки пробуете включить, запустить и т.п.?? а потом уже в инструкции читаете о возможных примочках?? :)) |
|
Igor67 Пользователь Сообщений: 3729 |
#9 10.07.2008 19:39:28 Про русский менталитет: |
Excel для Microsoft 365 Excel 2021 Excel 2019 Excel 2016 Excel 2013 Excel 2010 Еще…Меньше
В Excel есть несколько типов кнопок и цветных треугольников, которые могут отображаться в ячейке или рядом с нее. Эти кнопки и треугольники предоставляют полезные команды и сведения о содержимом ячейки и отображаются в нужный момент. В этой статье описано, что означают эти кнопки и треугольники и как с ними можно работать.
Кнопки, которые могут быть на вашем компьютере
Семь кнопок, которые могут отображаться рядом с ячейкой: Параметры автозавершения, Параметры вставки, Параметры автозавершения, Ошибка трассировки, Параметры вставки и Применение правила форматирования к .
Параметры автозамены
Кнопка Параметры авто исправления при нажатии указателя мыши на маленьком синем поле под текстом, который был автоматически исправлен. Например, если ввести в ячейку гиперссылки или адрес электронной почты, может появиться кнопка Параметры автоcorrect. Если вы нашли текст, который не нужно исправлять, можно отменить исправление или включить или отключить параметры авто исправления. Чтобы включить или отключить параметры автоcorrect, нажмите кнопку Параметры автозаверха и выберите один из вариантов из списка.
Дополнительные сведения см. в меню Выбор параметров автозаписи для написания прописных букв, орфографических и символов.
Параметры вставки
Кнопка Параметры в после вжатия текста или данных появится под в документом. Когда вы нажмете кнопку, появится список, который позволяет определить, как в нее врезать данные.
Доступные параметры зависят от типа в документе содержимого, программы, из которой вы в нее в последний раз в документе, и от формата текста, в который в него в него в последний раз в него в последний раз в которое в последний раз в которое в него войдет текст.
Дополнительные сведения см. в теме Перемещение и копирование ячеек и их содержимого.
Параметры автоза заполнения
Кнопка Параметры автозаполнеия может появиться под заполненным текстом или данными. Например, если ввести дату в ячейку, а затем перетащить ее вниз, чтобы заполнить ячейки под ней, может появиться кнопка Параметры автозаполнеия. При нажатии кнопки появится список параметров заполнения текста или данных.
Доступные параметры в списке зависят от содержимого, из которых вы заполняете данные, от программы, из которую вы в нее в настоящее время находитесь, а также от формата заполняемого текста или данных.
Дополнительные сведения см. в статье Автоматическое заполнение ячеек листа данными.
Источник ошибки
Рядом с , в которой возникает ошибка формулы, появится кнопка Ошибка трассировки, а в левом верхнем углу ячейки появится зеленый треугольник.
Если щелкнуть стрелку рядом с кнопкой, появится список вариантов проверки ошибок.
Дополнительные сведения см. в теме Обнаружение ошибок в формулах.
Параметры вставки
Рядом с вставленными ячейками, строками или столбцами может появиться кнопка Параметры вставки.
Если щелкнуть стрелку рядом с кнопкой, появится список параметров форматирования.
Примечание: Если вы не хотите, чтобы эта кнопка отображалась при каждой вставке форматных ячеек, строк или столбцов, вы можете отключить ее в меню Параметры файла >> Дополнительные параметры > При вырезании, копировании и вставке > снимите > рядом с кнопками Показать параметры вставки.
Применение правила форматирования к
Кнопка Применить правило форматирования используется для изменения способа изменения области данных условного форматирования в отчете.
Если щелкнуть стрелку рядом с кнопкой, появится список параметров области.
Цветные треугольники, которые можно увидеть на вашем компьютере
Два цветных треугольника, которые могут отображаться в ячейке, зеленый (ошибка формулы) и красный (комментарий).
Зеленый треугольник
|
Зеленый треугольник в левом верхнем углу ячейки указывает на ошибку в формуле в ячейке. Если вы выберете ячейку, появится кнопка трассировки ошибок. Щелкните стрелку рядом с кнопкой для списка параметров.
Дополнительные сведения см. в теме Обнаружение ошибок в формулах. |
Красный треугольник
|
Красный треугольник в правом верхнем углу ячейки указывает на то, что в ячейке находится заметка. Если наказать указатель мыши на треугольник, можно просмотреть текст заметки. |
Дополнительные сведения
Вы всегда можете задать вопрос специалисту Excel Tech Community или попросить помощи в сообществе Answers community.
Нужна дополнительная помощь?
Тогда у вас есть джокер, который не использовал элементы управления, а использовал текстовые поля. И не только текстовые поля, но и сгруппированные текстовые поля. В этом случае вы можете войти в режим разработки, как описано выше, и при нажатии правой кнопкой мыши на текстовом поле появится опция « Assign Macro
макрос». Выбор этого открывает диалоговое окно, которое позволяет вам сделать новый макрос или записать его. Конечно, вы будете удивляться , как это работает , если нет макроса уже назначен на этот Shape. Да, Shape not Textbox, потому что Excel не любит слишком четко различать. Затем вы некоторое время будете возиться и пытаться воссоздать исходный объект без определенного макроса, чтобы он перестал запускать макрос каждый раз, когда вы пытаетесь щелкнуть по вложенному текстовому полю. Вам нужно будет кликать по вложенным текстовым полям, пока вы не получите тот, который вам нужен, чтобы отобразить его как выделенный (подсказка: попробуйте щелкнуть правой кнопкой мыши сам текст). Вы можете даже искать и узнавать, как разгруппировать текстовые поля (выделите текстовое поле, посмотрите на ленту, где написано «Инструменты рисования», а затем перейдите на вкладку «Формат»). Как только нужный объект выделен, контекстное меню должно показать уже назначенный ему макрос и предложить опцию «Редактировать». Теперь вы сможете приступить к отладке или изменению кода спагетти VBA, несомненно оставленного «гуру». Вы можете даже искать определение «гуру»: духовный учитель, особенно тот, кто передает посвящение. Считайте себя «инициированным».
Как посмотреть какой макрос назначен кнопке
Вы можете использовать кнопку управления формы или кнопку (ActiveX) для запуска макроса, который выполняет действие, когда пользователь щелкает его. Обе эти кнопки также называются push-кнопками, которые можно настроить для автоматизации печати, фильтрации данных или вычисления чисел. Как правило, кнопки управления формы и ActiveX похожи по внешнему виду и функции. Однако между ними есть несколько отличий, которые объясняются в следующих разделах.
Кнопка (управление формы)
В разделах ниже вы узнаете, как добавить макрос на кнопку в Excel для Windows или Mac.
Примечание: ActiveX не поддерживаются на компьютере Mac.
Макрос и средства VBA находятся на вкладке Разработчик, которая по умолчанию скрыта.
Прежде всего нужно включить его. Дополнительные сведения см. в статье Показ вкладки «Разработчик».
Добавление кнопки (управление формы)
На вкладке Разработчик в группе Элементы управления нажмите кнопку Вставить, а затем в группе Элементы управления формы нажмитекнопку .
Щелкните на листе место, где должен быть расположен левый верхний угол кнопки. Появится всплывающее окно Назначение макроса.
Назначьте кнопке макрос и нажмите кнопку ОК.
Чтобы задать свойства кнопки, щелкните ее правой кнопкой мыши и выберите форматирование.
Добавление кнопки (ActiveX управления)
На вкладке Разработчик в группе Элементы управления нажмите кнопку Вставить, а затем вгруппе Элементы управления ActiveX нажмите кнопку .
Щелкните на том месте, где должен отображаться левый верхний угол кнопки.
В группе Элементы управления нажмите кнопку Код представления. При этом Visual Basic редактора. Убедитесь, что в списке справа выбрано нажатие кнопки. При нажатии кнопки CommandButton1_Click процедуры (см. рисунок ниже) запускаются эти два макроса: SelectC15 и HelloMessage.
В подпроцеду для кнопки сделайте следующее:
Введите имя существующего макроса в книге. Макрос можно найти, щелкнув Макрос в группе Код. С помощью кнопки можно запускать несколько макроса, вводя их имена в отдельных строках подпроцесса.
При необходимости добавьте собственный код VBA.
Закроем Visual Basic редактора и нажмите кнопку Режим конструктора режим конструктора, чтобы отключить режим конструктора.
Чтобы запустить код VBA, который теперь является частью кнопки, нажмите кнопку ActiveX, которую вы только что создали.
Чтобы изменить элемент ActiveX, убедитесь, что выбран режим конструктора. На вкладке Разработчик в группе Элементы управления нажмите кнопку Режим конструктора.
Чтобы задать свойства кнопки, на вкладке Разработчик в группе Элементы управления нажмите кнопку Свойства . Можно также щелкнуть правой кнопкой мыши кнопку и щелкнуть свойства .
Примечание: Перед тем как нажать кнопку Свойства, выделите объект, свойства которого требуется просмотреть или изменить.
Появится поле Свойства. Для получения дополнительных сведений о каждом свойстве выберите свойство и нажмите клавишу F1, чтобы отобразить соответствующий раздел справка по Visual Basic. Можно также ввести имя свойства в поле Поиск справки Visual Basic. В следующей таблице 2010 2010 2016 2016 2016 2016 201
Описание параметра
Необходимое свойство
Загружает ли его при открытом книге. (Игнорируется для ActiveX элементов управления.)
Может ли он получать фокус и отвечать на события, созданные пользователем.
Можно ли изменять элемент управления
Имя элемента управления
Способ привязки элемента управления к расположенным под ним ячейкам (не закреплен, можно перемещать, но нельзя изменять размер, можно перемещать и изменять размер)
Можно ли выводить элемент управления на печать
Является ли элемент управления видимым или скрытым
Атрибуты шрифта (полужирный, курсив, размер, зачеркивание, подчеркивание и насыщенность)
Bold, Italic, Size, StrikeThrough, Underline, Weight (форма)
Поясняющий текст элемента управления, определяющий или описывающий его
Будет ли содержимое элемента управления переноситься по словам в конце строки
Размер и положение
Будет ли размер элемента управления изменяться автоматически для отображения всего содержимого
Высота или ширина в пунктах
Height, Width (форма)
Расстояние от элемента управления до левого или верхнего края листа
Форматирование
Стиль фона (прозрачный или непрозрачный)
Цвет переднего плана
Наличие тени элемента управления
Изображение
Точечный рисунок, отображаемый в элементе управления
Положение рисунка относительно его заголовка (слева, сверху, справа и так далее)
Клавиатура и мышь
Сочетание клавиш для элемента управления
Настраиваемый значок мыши
Тип указателя, отображаемого при наведите указатель мыши на определенный объект (стандартный, стрелка, I-указатель и так далее).
Будет ли фокус при щелчке.
Макрос и средства VBA находятся на вкладке «Разработчик», которая по умолчанию скрыта, поэтому сначала нужно включить ее.
Перейдите в Excel > параметры. > ленты & панель инструментов.
В категории Настроить ленту в списке Основные вкладки установите флажок Разработчик, а затем нажмите кнопку Сохранить.
Добавление кнопки (управление формы)
На вкладке Разработчик нажмите кнопку .
Щелкните на листе место, где должен быть расположен левый верхний угол кнопки. Появится всплывающее окно Назначение макроса.
Примечание: Если кнопка уже вставлена, щелкните ее правой кнопкой мыши и выберите назначить макрос.
Назначьте кнопке макрос и нажмите кнопку ОК.
Чтобы задать свойства кнопки, щелкните ее правой кнопкой мыши и выберите форматирование.
Добавление кнопки (Visual Basic управления)
На вкладке Разработчик нажмите кнопку .
Щелкните место на том месте, где должен отображаться левый верхний угол кнопки.
Примечание: Если кнопка уже вставлена, щелкните ее правой кнопкой мыши и выберите назначить макрос.
В диалоговом окне Назначение макроса выберите Новый, который откроет редактор Visual Basic(VBE)в области со следующим кодом:
В подпроцеду для кнопки между строками Sub и End Sub сделайте следующее:
Введите имя существующего макроса в книге. Вы можете запускать несколько макроса с помощью кнопки, введя их имена в отдельных строках внутри под процедуры.
Добавьте собственный код VBA.
Нажмите кнопку Режим режим конструктора, чтобы режим конструктора отключен, а затем закроем Visual Basic редактора.
Чтобы изменить кнопку, щелкните ее правой кнопкой мыши ивыберите Visual Basic .
Чтобы задать свойства кнопки, щелкните ее правой кнопкой мыши и выберите форматирование.
Дополнительные сведения
Вы всегда можете задать вопрос специалисту Excel Tech Community или попросить помощи в сообществе Answers community.
Как узнать, какой макрос привязан к кнопке на вкладке приложения?
Уважаемые коллеги!
На вкладке Главная в пользовательской группе Новая группа имеется несколько пользовательских кнопок.
Как узнать, какие макросы привязаны к этим кнопкам?
2 Ответ от Alex_Gur 02.09.2015 09:44:10
- Alex_Gur
- Модератор
- Неактивен
- Откуда: Москва
- Зарегистрирован: 28.07.2011
- Сообщений: 2,758
- Поблагодарили: 492
Re: Как узнать, какой макрос привязан к кнопке на вкладке приложения?
Уважаемые коллеги!
Ответ на свой вопрос нашел сам:
Открываем вкладку Настройка ленты в Параметрах Word.
В правой части вкладки открываем пользовательскую группу, где находятся пользовательские кнопки и подводим курсор мыши к строке нужной кнопки (но не нажимаем на кнопку мыши).
Через небольшое время на экран выводится подсказка, в конце которой указан искомый макрос (см. рисунок в приложении).
Кнопка и макрос_а.JPG 109.02 Кб, файл не был скачан.
You don’t have the permssions to download the attachments of this post.
Сообщений [ 2 ]
Страницы 1
Чтобы отправить ответ, вы должны войти или зарегистрироваться
Похожие темы
Как узнать, какой макрос привязан к кнопке на вкладке приложения?
Если вы по роду своей деятельности работаете с документами, то вам очень часто приходится иметь дело с редактором текстов Microsoft Word. На портале о Microsoft Office Word вы узнаете про: как не ставить номер страниц в ворде 2007. Познакомиться с тонкостями работы в этой программе вы можете на форуме сайта Ворд Эксперт.
Здесь участники делятся друг с другом своими вариантами настроек и принципов форматирования и редактирования текстов. На портале о Microsoft Office Word вы узнаете про: рамки на тектсовом документе по гост. На форуме много внимания уделено написанию макросов, созданию шаблонов и другим способам автоматизировать работу Ворда. На портале о Microsoft Office Word вы узнаете про: заменить одно слово другим vba. Также можно найти информацию по различию в настройках версий программы.
В специальных подразделах возможно оставить заявки или позаимствовать готовые решения. Наш сайт о Microsoft Office Word даст ответ про: как переустановить основной шрифт.
Как записать макрос в Excel? Пошаговая инструкция.
Макрос — это код, написанный на встроенном в Excel языке VBA (Visual Basic for Application). Макросы могут создаваться как вручную, так и записываться автоматически с помощью так называемого макрорекодера.
Макрорекодер — это инструмент в Excel, который пошагово записывает все что вы выполняете в Excel и преобразует это в код на языке VBA. Макрорекодер создает очень подробный код (как мы увидим позже), который вы сможете при необходимости отредактировать в дальнейшем.
Записанный макрос можно будет запускать неограниченное количество раз и Excel повторит все записанные шаги. Это означает, что даже если вы ничего не знаете о VBA, вы можете автоматизировать некоторые задачи, просто записав свои шаги и затем повторно использовать их позже.
Теперь давайте погрузимся и посмотрим, как записать макрос в Excel.
Отображение вкладки «Разработчик» в ленте меню
Перед тем как записывать макрос, нужно добавить на ленту меню Excel вкладку «Разработчик». Для этого выполните следующие шаги:
- Щелкните правой кнопкой мыши по любой из существующих вкладок на ленте и нажмите «Настроить ленту». Он откроет диалоговое окно «Параметры Excel».
- В диалоговом окне «Параметры Excel» у вас будут параметры «Настроить ленту». Справа на панели «Основные вкладки» установите флажок «Разработчик».
- Нажмите «ОК».
В результате на ленте меню появится вкладка «Разработчик»
Запись макроса в Excel
Теперь давайте запишем очень простой макрос, который выбирает ячейку и вводит в нее текст, например «Excel».
Вот шаги для записи такого макроса:
- Перейдите на вкладку «Разработчик».
- В группе «Код» нажмите кнопку «Запись макроса». Откроется одноименное диалоговое окно.
- В диалоговом окне «Запись макроса» введите имя для своего макроса, например «ВводТекста». Есть несколько условий именования, которые необходимо соблюдать при назначении макроса. Например, вы не можете использовать пробелы между ними. Обычно я предпочитаю сохранять имена макросов как одно слово, с разными частями с заглавным первым алфавитом. Вы также можете использовать подчеркивание для разделения двух слов — например, «Ввод_текста».
- Если вы хотите, то можете задать сочетание клавиш. В этом случае мы будем использовать ярлык Ctrl + Shift + N. Помните, что сочетание, которое вы указываете, будет отменять любые существующие горячие клавиши в вашей книге. Например, если вы назначили сочетание Ctrl + S, вы не сможете использовать это для сохранения рабочей книги (вместо этого, каждый раз, когда вы его используете, он выполняет макрос).
- В поле «Сохранить в» убедитесь, что выбрана опция «Эта книга». Этот шаг гарантирует, что макрос является частью рабочей книги. Он будет там, когда вы сохраните его и снова откроете, или даже если вы поделитесь файлом с кем-то.
- Введите описание при необходимости. Обычно я этого не делаю, но если у вас много макросов, лучше указать, чтобы в будущем не забыть что делает макрос.
- Нажмите «ОК». Как только вы нажмете OK, Excel начнет записывать ваши действия. Вы можете увидеть кнопку «Остановить запись» на вкладке «Разработчик», которая указывает, что выполняется запить макроса.
- Выберите ячейку A2.
- Введите текст «Excel» (или вы можете использовать свое имя).
- Нажмите клавишу Enter. Вы попадете на ячейку A3.
- Нажмите кнопку «Остановить запись» на вкладке «Разработчик».
Поздравляем! Вы только что записали свой первый макрос в Excel. Хотя макрос не делает ничего полезного, но он поможет нам понять как работает макрорекордер в Excel.
Теперь давайте рассмотрим код который записал макрорекодер. Выполните следующие действия, чтобы открыть редактор кода:
- Удалите текст в ячейке A2. Это нужно, чтобы проверить будет ли макрос вставлять текст в ячейку A2 или нет.
- Выберите любую ячейку — кроме A2. Это нужно проверить, выбирает ли макрос ячейку A2 или нет.
- Перейдите на вкладку «Разработчик».
- В группе «Код» нажмите кнопку «Макросы».
- В диалоговом окне «Макрос» щелкните макрос «ВводТекста».
- Нажмите кнопку «Выполнить».
Вы увидите, что как только вы нажмете кнопку «Выполнить», текст «Excel» будет вставлен в ячейку A2 и выбрана ячейка A3. Это происходит за миллисекунды. Но на самом деле макрос последовательно выполнил записанные действия.
Примечание. Вы также можете запустить макрос с помощью сочетания клавиш Ctrl + Shift + N (удерживайте клавиши Ctrl и Shift, а затем нажмите клавишу N). Это тот же самый ярлык, который мы назначили макросу при его записи.
Что записывает макрос?
Теперь перейдем к редактору кода и посмотрим что у нас получилось.
Вот шаги по открытию редактора VB в Excel:
- Перейдите на вкладку «Разработчик».
- В группе «Код» нажмите кнопку «Visual Basic».
Вы также можете использовать комбинацию клавиш Alt + F11 и перейти в редактор кода VBA.
Рассмотрим сам редактор кода. Далее коротко опишем интерфейс редактора.
- Панель меню: содержит команды, которые можно использовать во время работы с редактором VB.
- Панель инструментов — похожа на панель быстрого доступа в Excel. Вы можете добавить к ней дополнительные инструменты, которыми часто пользуетесь.
- Окно проектов (Project Explorer) — здесь Excel перечисляет все книги и все объекты в каждой книге. Например, если у нас есть книга с 3 рабочими листами, она появится в Project Explorer. Здесь есть несколько дополнительных объектов, таких как модули, пользовательские формы и модули классов.
- Окно кода — собственно сам код VBA размещается в этом окне. Для каждого объекта, указанного в проводнике проекта, есть окно кода, например, рабочие листы, книги, модули и т. д. В этом уроке мы увидим, что записанный макрос находится в окне кода модуля.
- Окно свойств — вы можете увидеть свойства каждого объекта в этом окне. Я часто использую это окно для обозначения объектов или изменения их свойств.
- Immediate Window (окно предпросмотра) — На начальном этапе оно вам не пригодится. Оно полезно, когда вы хотите протестировать шаги или во время отладки. Он по умолчанию не отображается, и вы можете его отобразить, щелкнув вкладку «View» и выбрав опцию «Immediate Window».
Когда мы записали макрос «ВводТекста», в редакторе VB произошли следующие вещи:
- Был добавлен новый модуль.
- Макрос был записан с именем, которое мы указали — «ВводТекста»
- В окне кода добавлена новая процедура.
Поэтому, если вы дважды щелкните по модулю (в нашем случае модуль 1), появится окно кода, как показано ниже.
Вот код, который записан макрорекодером:
В VBA, любая строка , которая следует за ‘ (знак апострофа) не выполняется. Это комментарий, который предназначен только для информационных целей. Если вы удалите первые пять строк этого кода, макрос по-прежнему будет работать.
Теперь давайте пробежим по каждой строке кода и опишем что и зачем.
Код начинается с Sub, за которым следует имя макроса и пустые круглые скобки. Sub — сокращение для подпрограммы. Каждая подпрограмма (также называемая процедурой) в VBA начинается с Sub и заканчивается End Sub.
- Range(«A2»).Select — эта строка выбирает ячейку A2.
- ActiveCell.FormulaR1C1 = «Excel» — эта строка вводит текст «Excel» в активной ячейке. Поскольку мы выбрали ячейку A2 в качестве первого шага, она становится нашей активной ячейкой.
- Range(«A3»).Select — выбор ячейки A3. Это происходит, когда мы нажимаем клавишу Enter после ввода текста, результатом которого является выбор ячейки A3.
Надеюсь, что у вас есть некоторое базовое понимание того, как записывать макрос в Excel.
Обращаем внимание, что код, записанный через макрорекордер, как правило, не является эффективным и оптимизированным кодом. Макрорекордер часто добавляет дополнительные ненужные действия. Но это не значит, что не нужно пользоваться макрорекодером. Для тех, кто только изучает VBA , макрорекордер может быть отличным способом проанализировать и понять как все работает в VBA.
Абсолютная и относительная запись макроса
Вы уже знаете про абсолютные и относительные ссылки в Excel? Если вы используете абсолютную ссылку для записи макроса, код VBA всегда будет ссылаться на те же ячейки, которые вы использовали. Например, если вы выберете ячейку A2 и введете текст «Excel», то каждый раз — независимо от того, где вы находитесь на листе и независимо от того, какая ячейка выбрана, ваш код будет вводить текст «Excel» в ячейку A2.
Если вы используете параметр относительной ссылки для записи макроса, VBA не будет привязываться к конкретному адресу ячейки. В этом случае программа будет «двигаться» относительно активной ячейки. Например, предположим, что вы уже выбрали ячейку A1, и вы начинаете запись макроса в режиме относительной ссылки. Теперь вы выбираете ячейку A2, вводите текст Excel и нажмите клавишу Enter. Теперь, если вы запустите этот макрос, он не вернется в ячейку A2, вместо этого он будет перемещаться относительно активной ячейки. Например, если выбрана ячейка B3, она переместится на B4, запишет текст «Excel» и затем перейдет к ячейке K5.
Теперь давайте запишем макрос в режиме относительных ссылок:
- Выберите ячейку A1.
- Перейдите на вкладку «Разработчик».
- В группе «Код» нажмите кнопку «Относительные ссылки». Он будет подсвечиваться, указывая, что он включен.
- Нажмите кнопку «Запись макроса».
- В диалоговом окне «Запись макроса» введите имя для своего макроса. Например, имя «ОтносительныеСсылки».
- В опции «Сохранить в» выберите «Эта книга».
- Нажмите «ОК».
- Выберите ячейку A2.
- Введите текст «Excel» (или другой как вам нравится).
- Нажмите клавишу Enter. Курсор переместиться в ячейку A3.
- Нажмите кнопку «Остановить запись» на вкладке «Разработчик».
Макрос в режиме относительных ссылок будет сохранен.
Теперь сделайте следующее.
- Выберите любую ячейку (кроме A1).
- Перейдите на вкладку «Разработчик».
- В группе «Код» нажмите кнопку «Макросы».
- В диалоговом окне «Макрос» кликните на сохраненный макрос «ОтносительныеСсылки».
- Нажмите кнопку «Выполнить».
Как вы заметите, макрос записал текст «Excel» не в ячейки A2. Это произошло, потому что вы записали макрос в режиме относительной ссылки. Таким образом, курсор перемещается относительно активной ячейки. Например, если вы сделаете это, когда выбрана ячейка B3, она войдет в текст Excel — ячейка B4 и в конечном итоге выберет ячейку B5.
Вот код, который записал макрорекодер:
Обратите внимание, что в коде нет ссылок на ячейки B3 или B4. Макрос использует Activecell для ссылки на текущую ячейку и смещение относительно этой ячейки.
Не обращайте внимание на часть кода Range(«A1»). Это один из тех случаев, когда макрорекодер добавляет ненужный код, который не имеет никакой цели и может быть удален. Без него код будет работать отлично.
Что нельзя сделать с помощью макрорекодера?
Макро-рекордер отлично подходит для вас в Excel и записывает ваши точные шаги, но может вам не подойти, когда вам нужно сделать что-то большее.
- Вы не можете выполнить код без выбора объекта. Например, если вы хотите, чтобы макрос перешел на следующий рабочий лист и выделил все заполненные ячейки в столбце A, не выходя из текущей рабочей таблицы, макрорекодер не сможет этого сделать. В таких случаях вам нужно вручную редактировать код.
- Вы не можете создать пользовательскую функцию с помощью макрорекордера. С помощью VBA вы можете создавать пользовательские функции, которые можно использовать на рабочем листе в качестве обычных функций.
- Вы не можете создавать циклы с помощью макрорекордера. Но можете записать одно действие, а цикл добавить вручную в редакторе кода.
- Вы не можете анализировать условия: вы можете проверить условия в коде с помощью макрорекордера. Если вы пишете код VBA вручную, вы можете использовать операторы IF Then Else для анализа условия и запуска кода, если true (или другой код, если false).
Расширение файлов Excel, которые содержат макросы
Когда вы записываете макрос или вручную записываете код VBA в Excel, вам необходимо сохранить файл с расширением файла с поддержкой макросов (.xlsm).
До Excel 2007 был достаточен один формат файла — .xls. Но с 2007 года .xlsx был представлен как стандартное расширение файла. Файлы, сохраненные как .xlsx, не могут содержать в себе макрос. Поэтому, если у вас есть файл с расширением .xlsx, и вы записываете / записываете макрос и сохраняете его, он будет предупреждать вас о сохранении его в формате с поддержкой макросов и покажет вам следующее диалоговое окно:
Если вы выберете «Нет», Excel сохранить файл в формате с поддержкой макросов. Но если вы нажмете «Да», Excel автоматически удалит весь код из вашей книги и сохранит файл как книгу в формате .xlsx. Поэтому, если в вашей книге есть макрос, вам нужно сохранить его в формате .xlsm, чтобы сохранить этот макрос.