Excel для Microsoft 365 Excel для Microsoft 365 для Mac Excel 2021 для Mac Excel 2019 Excel 2019 для Mac Excel 2016 Excel 2016 для Mac Excel 2013 Excel 2010 Еще…Меньше
Если у вас есть Microsoft Excel задачи, которые вы делаете несколько раз, вы можете записать макрос, чтобы автоматизировать эти задачи. Макрос — это действие или набор действий, которые можно выполнить сколько угодно раз. При создании макроса записуются щелчки мышью и нажатия клавиш. После создания макроса его можно отредактировать, чтобы внести незначительные изменения в его работу.
Предположим, что каждый месяц вы создаете отчет для бухгалтера. Вы хотите отформатировать имена клиентов с просроченными учетными записями красным цветом, а также применить полужирное на форматирование. Вы можете создать и запустить макрос, который быстро применяет эти изменения форматирования к выбранным ячейкам.
Процедура
|
Перед записью макроса Макросы и средства VBA находятся на вкладке Разработчик, которая по умолчанию скрыта, поэтому сначала нужно включить ее. Дополнительные сведения см. в статье Отображение вкладки «Разработчик». |
|
Запись макроса
|
|
Подробнее о макросах Вы можете узнать немного о языке программирования Visual Basic путем редактирования макроса. Чтобы изменить макрос, в группе Код на вкладке Разработчик нажмите кнопку Макрос, выберите имя макроса и нажмите кнопку Изменить. При этом Visual Basic редактора. Узнайте, как записанные действия отображаются как код. Возможно, какой-то код вам понятен, а часть может показаться немного неявным. Поэкспериментируйте с кодом, закройте редактор Visual Basic и снова запустите макрос. На этот раз посмотрите, не произойдет ли что-то другое! |
Дальнейшие действия
-
Дополнительные информацию о создании макроса см. в теме Создание и удаление макроса.
-
Чтобы узнать, как запускать макрос, см. в этой теме.
Процедура
|
Перед записью макроса Убедитесь, что на ленте отображается вкладка Разработчик. По умолчанию вкладка Разработчик не отображается, поэтому сделайте следующее:
|
|
Запись макроса
|
|
Подробнее о макросах Вы можете узнать немного о языке программирования Visual Basic путем редактирования макроса. Чтобы изменить макрос, на вкладке Разработчик нажмите кнопку Макрос ,выберите имя макроса и нажмите кнопку Изменить. При этом Visual Basic редактора. Узнайте, как записанные действия отображаются как код. Возможно, какой-то код вам понятен, а часть может показаться немного неявным. Поэкспериментируйте с кодом, закройте редактор Visual Basic и снова запустите макрос. На этот раз посмотрите, не произойдет ли что-то другое! |
Дополнительные сведения
Вы всегда можете задать вопрос специалисту Excel Tech Community или попросить помощи в сообществе Answers community.
Нужна дополнительная помощь?
#Руководства
- 23 май 2022
-
0
Как с помощью макросов автоматизировать рутинные задачи в Excel? Какие команды они выполняют? Как создать макрос новичку? Разбираемся на примере.
Иллюстрация: Meery Mary для Skillbox Media
Рассказывает просто о сложных вещах из мира бизнеса и управления. До редактуры — пять лет в банке и три — в оценке имущества. Разбирается в Excel, финансах и корпоративной жизни.
Макрос (или макрокоманда) в Excel — алгоритм действий в программе, который объединён в одну команду. С помощью макроса можно выполнить несколько шагов в Excel, нажав на одну кнопку в меню или на сочетание клавиш.
Обычно макросы используют для автоматизации рутинной работы — вместо того чтобы выполнять десяток повторяющихся действий, пользователь записывает одну команду и затем запускает её, когда нужно совершить эти действия снова.
Например, если нужно добавить название компании в несколько десятков документов и отформатировать его вид под корпоративный дизайн, можно делать это в каждом документе отдельно, а можно записать ход действий при создании первого документа в макрос — и затем применить его ко всем остальным. Второй вариант будет гораздо проще и быстрее.
В статье разберёмся:
- как работают макросы и как с их помощью избавиться от рутины в Excel;
- какие способы создания макросов существуют и как подготовиться к их записи;
- как записать и запустить макрос начинающим пользователям — на примере со скриншотами.
Общий принцип работы макросов такой:
- Пользователь записывает последовательность действий, которые нужно выполнить в Excel, — о том, как это сделать, поговорим ниже.
- Excel обрабатывает эти действия и создаёт для них одну общую команду. Получается макрос.
- Пользователь запускает этот макрос, когда ему нужно выполнить эту же последовательность действий ещё раз. При записи макроса можно задать комбинацию клавиш или создать новую кнопку на главной панели Excel — если нажать на них, макрос запустится автоматически.
Макросы могут выполнять любые действия, которые в них запишет пользователь. Вот некоторые команды, которые они умеют делать в Excel:
- Автоматизировать повторяющиеся процедуры.
Например, если пользователю нужно каждый месяц собирать отчёты из нескольких файлов в один, а порядок действий каждый раз один и тот же, можно записать макрос и запускать его ежемесячно.
- Объединять работу нескольких программ Microsoft Office.
Например, с помощью одного макроса можно создать таблицу в Excel, вставить и сохранить её в документе Word и затем отправить в письме по Outlook.
- Искать ячейки с данными и переносить их в другие файлы.
Этот макрос пригодится, когда нужно найти информацию в нескольких объёмных документах. Макрос самостоятельно отыщет её и принесёт в заданный файл за несколько секунд.
- Форматировать таблицы и заполнять их текстом.
Например, если нужно привести несколько таблиц к одному виду и дополнить их новыми данными, можно записать макрос при форматировании первой таблицы и потом применить его ко всем остальным.
- Создавать шаблоны для ввода данных.
Команда подойдёт, когда, например, нужно создать анкету для сбора данных от сотрудников. С помощью макроса можно сформировать такой шаблон и разослать его по корпоративной почте.
- Создавать новые функции Excel.
Если пользователю понадобятся дополнительные функции, которых ещё нет в Excel, он сможет записать их самостоятельно. Все базовые функции Excel — это тоже макросы.
Все перечисленные команды, а также любые другие команды пользователя можно комбинировать друг с другом и на их основе создавать макросы под свои потребности.
В Excel и других программах Microsoft Office макросы создаются в виде кода на языке программирования VBA (Visual Basic for Applications). Этот язык разработан в Microsoft специально для программ компании — он представляет собой упрощённую версию языка Visual Basic. Но это не значит, что для записи макроса нужно уметь кодить.
Есть два способа создания макроса в Excel:
- Написать макрос вручную.
Это способ для продвинутых пользователей. Предполагается, что они откроют окно Visual Basic в Еxcel и самостоятельно напишут последовательность действий для макроса в виде кода.
- Записать макрос с помощью кнопки меню Excel.
Способ подойдёт новичкам. В этом варианте Excel запишет программный код вместо пользователя. Нужно нажать кнопку записи и выполнить все действия, которые планируется включить в макрос, и после этого остановить запись — Excel переведёт каждое действие и выдаст алгоритм на языке VBA.
Разберёмся на примере, как создать макрос с помощью второго способа.
Допустим, специальный сервис автосалона выгрузил отчёт по продажам за три месяца первого квартала в формате таблиц Excel. Эти таблицы содержат всю необходимую информацию, но при этом никак не отформатированы: колонки слиплись друг с другом и не видны полностью, шапка таблицы не выделена и сливается с другими строками, часть данных не отображается.
Скриншот: Skillbox Media
Пользоваться таким отчётом неудобно — нужно сделать его наглядным. Запишем макрос при форматировании таблицы с продажами за январь и затем применим его к двум другим таблицам.
Готовимся к записи макроса
Кнопки для работы с макросами в Excel находятся во вкладке «Разработчик». Эта вкладка по умолчанию скрыта, поэтому для начала разблокируем её.
В операционной системе Windows это делается так: переходим во вкладку «Файл» и выбираем пункты «Параметры» → «Настройка ленты». В открывшемся окне в разделе «Основные вкладки» находим пункт «Разработчик», отмечаем его галочкой и нажимаем кнопку «ОК» → в основном меню Excel появляется новая вкладка «Разработчик».
В операционной системе macOS это нужно делать по-другому. В самом верхнем меню нажимаем на вкладку «Excel» и выбираем пункт «Параметры…».
Скриншот: Skillbox Media
В появившемся окне нажимаем кнопку «Лента и панель».
Скриншот: Skillbox Media
Затем в правой панели «Настроить ленту» ищем пункт «Разработчик» и отмечаем его галочкой. Нажимаем «Сохранить».
Скриншот: Skillbox Media
Готово — вкладка «Разработчик» появилась на основной панели Excel.
Скриншот: Skillbox Media
Чтобы Excel смог сохранить и в дальнейшем использовать макрос, нужно пересохранить документ в формате, который поддерживает макросы. Это делается через команду «Сохранить как» на главной панели. В появившемся меню нужно выбрать формат «Книга Excel с поддержкой макросов».
Скриншот: Skillbox Media
Перед началом записи макроса важно знать об особенностях его работы:
- Макрос записывает все действия пользователя.
После старта записи макрос начнёт регистрировать все клики мышки и все нажатия клавиш. Поэтому перед записью последовательности лучше хорошо отработать её, чтобы не добавлять лишних действий и не удлинять код. Если требуется записать длинную последовательность задач — лучше разбить её на несколько коротких и записать несколько макросов.
- Работу макроса нельзя отменить.
Все действия, которые выполняет запущенный макрос, остаются в файле навсегда. Поэтому перед тем, как запускать макрос в первый раз, лучше создать копию всего файла. Если что-то пойдёт не так, можно будет просто закрыть его и переписать макрос в созданной копии.
- Макрос выполняет свой алгоритм только для записанного диапазона таблиц.
Если при записи макроса пользователь выбирал диапазон таблицы, то и при запуске макроса в другом месте он выполнит свой алгоритм только в рамках этого диапазона. Если добавить новую строку, макрос к ней применяться не будет. Поэтому при записи макроса можно сразу выбирать большее количество строк — как это сделать, показываем ниже.
Для начала записи макроса перейдём на вкладку «Разработчик» и нажмём кнопку «Записать макрос».
Скриншот: Skillbox Media
Появляется окно для заполнения параметров макроса. Нужно заполнить поля: «Имя макроса», «Сохранить в», «Сочетание клавиш», «Описание».
Скриншот: Skillbox Media
«Имя макроса» — здесь нужно придумать и ввести название для макроса. Лучше сделать его логически понятным, чтобы в дальнейшем можно было быстро его найти.
Первым символом в названии обязательно должна быть буква. Другие символы могут быть буквами или цифрами. Важно не использовать пробелы в названии — их можно заменить символом подчёркивания.
«Сохранить в» — здесь нужно выбрать книгу, в которую макрос сохранится после записи.
Если выбрать параметр «Эта книга», макрос будет доступен при работе только в этом файле Excel. Чтобы макрос был доступен всегда, нужно выбрать параметр «Личная книга макросов» — Excel создаст личную книгу макросов и сохранит новый макрос в неё.
«Сочетание клавиш» — здесь к уже выбранным двум клавишам (Ctrl + Shift в системе Windows и Option + Cmd в системе macOS) нужно добавить третью клавишу. Это должна быть строчная или прописная буква, которую ещё не используют в других быстрых командах компьютера или программы Excel.
В дальнейшем при нажатии этих трёх клавиш записанный макрос будет запускаться автоматически.
«Описание» — необязательное поле, но лучше его заполнять. Например, можно ввести туда последовательность действий, которые планируется записать в этом макросе. Так не придётся вспоминать, какие именно команды выполнит этот макрос, если нужно будет запустить его позже. Плюс будет проще ориентироваться среди других макросов.
В нашем случае с форматированием таблицы заполним поля записи макроса следующим образом и нажмём «ОК».
Скриншот: Skillbox Media
После этого начнётся запись макроса — в нижнем левом углу окна Excel появится значок записи.
Скриншот: Skillbox Media
Пока идёт запись, форматируем таблицу с продажами за январь: меняем ширину всех столбцов, данные во всех ячейках располагаем по центру, выделяем шапку таблицы цветом и жирным шрифтом, рисуем границы.
Важно: в нашем случае у таблиц продаж за январь, февраль и март одинаковое количество столбцов, но разное количество строк. Чтобы в случае со второй и третьей таблицей макрос сработал корректно, при форматировании выделим диапазон так, чтобы в него попали не только строки самой таблицы, но и строки ниже неё. Для этого нужно выделить столбцы в строке с их буквенным обозначением A–G, как на рисунке ниже.
Скриншот: Skillbox Media
Если выбрать диапазон только в рамках первой таблицы, то после запуска макроса в таблице с большим количеством строк она отформатируется только частично.
Скриншот: Skillbox Media
После всех манипуляций с оформлением таблица примет такой вид:
Скриншот: Skillbox Media
Проверяем, все ли действия с таблицей мы выполнили, и останавливаем запись макроса. Сделать это можно двумя способами:
- Нажать на кнопку записи в нижнем левом углу.
- Перейти во вкладку «Разработчик» и нажать кнопку «Остановить запись».
Скриншот: Skillbox Media
Готово — мы создали макрос для форматирования таблиц в границах столбцов A–G. Теперь его можно применить к другим таблицам.
Запускаем макрос
Перейдём в лист со второй таблицей «Февраль_2022». В первоначальном виде она такая же нечитаемая, как и первая таблица до форматирования.
Скриншот: Skillbox Media
Отформатируем её с помощью записанного макроса. Запустить макрос можно двумя способами:
- Нажать комбинацию клавиш, которую выбрали при заполнении параметров макроса — в нашем случае Option + Cmd + Ф.
- Перейти во вкладку «Разработчик» и нажать кнопку «Макросы».
Скриншот: Skillbox Media
Появляется окно — там выбираем макрос, который нужно запустить. В нашем случае он один — «Форматирование_таблицы». Под ним отображается описание того, какие действия он включает. Нажимаем «Выполнить».
Скриншот: Skillbox Media
Готово — вторая таблица с помощью макроса форматируется так же, как и первая.
Скриншот: Skillbox Media
То же самое можно сделать и на третьем листе для таблицы продаж за март. Более того, этот же макрос можно будет запустить и в следующем квартале, когда сервис автосалона выгрузит таблицы с новыми данными.
Научитесь: Excel + Google Таблицы с нуля до PRO
Узнать больше
Многие люди боятся использовать макросы в Excel, потому что считают их довольно сложными для понимания. Все потому, что они связаны с программированием. Но на практике все оказывается значительно проще, чем может показаться на первый взгляд. В программировании важно научиться строить алгоритмы. И если человек умеет кодить хотя бы на одном языке, ему значительно проще усвоить все остальные.
Мы приведем некоторые примеры макросов Excel, которые станут верными помощниками в выполнении наиболее частых задач.
Содержание
- Понятие макроса
- Когда какой тип записи макросов использовать?
- Пример использования макросов №1
- Пример 2
- Пример 3
- Пример 4
- Пример 5
- Пример 6
- Рекомендации по использованию макросов
- Выводы
Понятие макроса
Термин «Макрос» слышало множество людей. Нередко при запуске таблицы появляется предупреждение: “Этот документ использует макросы, способные навредить данному компьютеру, поэтому они отключены с целью защиты от вредоносных действий”.
Макрос – действенный способ автоматизировать самые частые действия, которые нужно выполнять в электронных таблицах. Макросы – это разновидность программирования. Разработка этих подпрограмм осуществляется с помощью языка VBA. Впрочем, некоторые виды макросов не требуют навыков программирования. Ведь существует еще такое понятие, как макрорекордер. Достаточно его включить и совершить некоторые действия, как далее они будут повторяться по нажатию одной кнопки.
Макросы могут быть реально опасными. Поскольку при их написании используется язык программирования, с его помощью можно создать настоящий вирус, который способен повредить информацию, а также собирать данные для злоумышленников (особенно опасно, если в таблице есть банковские данные, пароли и так далее).
Также макрос может запустить реальную троянскую программу на компьютере. Поэтому, чтобы не допустить вредоносных действий со стороны стороннего макроса, не стоит запускать макросы из сторонних источников, которым не доверяют.
Значительно проще объяснить, зачем нужны макросы, на реальном примере. Например, необходимо каждый день удалять из электронной таблицы несколько столбцов, а потом добавлять новые строки. Это невероятно утомительное занятие, отнимающее много времени. Если же воспользоваться макросами, есть реальная возможность значительно его сэкономить.
Макросы можно запускать по нажатию определенной комбинации клавиш. Например, если нажать Ctrl+J, можно запустить подпрограмму.
Интересный факт: известная программа бухгалтерского учета 1C изначально очень напоминала Excel, но потом ее функционал расширился до текущего.
Если же нужно давать компьютеру сложные инструкции, можно воспользоваться редактором Visual Basic, примеры кода в котором мы и рассмотрим немного позже.
Когда какой тип записи макросов использовать?
Если необходимо автоматизировать простейшие действия, достаточно использовать встроенный инструмент для записи макросов. То есть, если не приходится прописывать никаких условий, переменных и других подобных вещей. Просто обычная последовательность действий.
Если же необходимо программировать сложные действия, то тогда придется пользоваться встроенной средой VBA. Например, если необходимо записать в массив все элементы какого-то диапазона значений, определить его длительность, и при условии, что количество элементов массива не превышает определенного числа, выдавать какое-то сообщение. Здесь стандартного инструмента для записи макросов окажется недостаточно, необходимо изучать язык программирования и записывать команды в специальной среде. А интерпретатор в дальнейшем будет выполнять написанный код.
Пример использования макросов №1
Сперва этот пример кода использовался для демонстрации комментариев кода, написанного на VBA. Но поскольку он включает и иные возможности языка, он может применяться для демонстрации следующих функций:
- Объявление переменных.
- Указание ссылок на ячейки Excel.
- Применение цикла типа For.
- Применение условного оператора.
- Отображение оповещения.
‘ Подпрограмма для поиска ячеек с адресами A1-A100 текущего активного листа
‘ и поиска ячеек, в которых содержится требуемая строка
Sub Find_String(sFindText As String)
Dim i As Integer ‘ Целочисленная переменная, которая используется в цикле типа «For»
Dim iRowNumber As Integer ‘ Целочисленная переменная, предназначенная для сохранения результата
iRowNumber = 0
‘ Цикл через ячейки A1-A100 до тех пор, пока не будет найдена строка ‘sFindText’
For i = 1 To 100
If Cells(i, 1).Value = sFindText Then
‘ Совпадение обнаружено для заданной строки
‘ Сохранение текущего номера строки и выход из цикла
iRowNumber = i
Exit For
End If
Next i
‘ Всплывающее сообщение, информирующее пользователя о найденной строке и ее номере
If iRowNumber = 0 Then
MsgBox «String » & sFindText & » not found»
Else
MsgBox «String » & sFindText & » found in cell A» & iRowNumber
End If
End Sub
Пример 2
Эта процедура перечисляет все значения числовой последовательности Фибоначчи, вплоть до 1000. В этом примере приводятся следующие возможности макросов Excel:
- Объявление переменных.
- Цикл Do While.
- Ссылки на ячейки текущего листа Excel.
- Условный оператор.
‘ Подпрограмма для перечисления всех значений последовательности Fibonacci для всех значений ниже тысячи
Sub Fibonacci()
Dim i As Integer ‘ счетчик для позиции в серии значений
Dim iFib As Integer ‘ сохраняет текущее значение в серии
Dim iFib_Next As Integer ‘ сохраняет следующее значение в серии
Dim iStep As Integer ‘ хранит размер следующего шага
‘ Инициализация переменных variables i и iFib_Next
i = 1
iFib_Next = 0
‘ Цикл Do While, который исполняется до тех пор, пока номер
‘ числа в последовательности Фибоначчи меньше 1000.
Do While iFib_Next < 1000
If i = 1 Then
‘ Специальный случай для первой записи в серии
iStep = 1
iFib = 0
Else
‘ Сохраняется следующий размер шага, перед перезаписью
‘ текущей записи в серии
iStep = iFib
iFib = iFib_Next
End If
‘ Печать текущего значения последовательности Фибоначчи для столбца А
‘ текущего листа
Cells(i, 1).Value = iFib
‘ Вычисление следующего значения последовательности и увеличение
‘ маркера позиции на 1
iFib_Next = iFib + iStep
i = i + 1
Loop
End Sub
Пример 3
Следующий пример подпрограммы читает значения с ячейки в колонке A активного листа, пока не найдет пустую ячейку. Вся полученная информация сохраняется в массиве. Это простой пример макросов в электронных таблицах, который показывает:
- Как объявлять переменные.
- Работу динамического массива.
- Цикл Do Until.
- Ссылки на ячейки в текущем листе Excel.
- Встроенную функцию Ubound, которая предназначена для определения размера массива.
‘ Подпрограмма, которая хранит значения колонки А текущего листа
‘ в массиве
Sub GetCellValues()
Dim iRow As Integer ‘ сохраняется текущий номер строки
Dim dCellValues() As Double ‘ массив, в котором хранятся значения ячеек
iRow = 1
ReDim dCellValues(1 To 10)
‘ Цикл Do Until, который извлекает значение каждой ячейки в столбце А
‘ активного листа до тех пор, пока ячейка не окажется пустой
Do Until IsEmpty(Cells(iRow, 1))
‘ Проверка, достаточно ли большой массив dCellValues
‘ Если нет, используется ReDim, чтобы увеличить размер массива на 10 элементов.
If UBound(dCellValues) < iRow Then
ReDim Preserve dCellValues(1 To iRow + 9)
End If
‘ Сохраняется текущая ячейка в массиве CellValues
dCellValues(iRow) = Cells(iRow, 1).Value
iRow = iRow + 1
Loop
End Sub
Пример 4
Следующая процедура «Sub» читает содержимое ячеек из колонки А другого листа, имеющего название «Sheet2» и с этими значениями осуществляет арифметические операции. Результат вычислений пишется в колонке А текущего листа.
Этот пример показывает:
- Как объявлять переменные.
- Объекты Excel.
- Цикл Do Until.
- Доступ к листам электронных таблиц и диапазонам ячеек с текущей книги.
‘ Подпрограмма, запускающая цикл через значения в колонке А текущего листа
‘ «Sheet2», perform arithmetic operations on each value, and write the
‘ result into Column A of the current Active Worksheet («Sheet1»)
Sub Transfer_ColA()
Dim i As Integer
Dim Col As Range
Dim dVal As Double
‘ Установить переменную Col в колонку А листа 2
Set Col = Sheets(«Sheet2»).Columns(«A»)
i = 1
‘ Прохождение цикла через каждую ячейку колонки ‘Col’ до тех пор, пока
‘ не будет обнаружена пустая ячейка
Do Until IsEmpty(Col.Cells(i))
‘ Применение арифметических операций к значению текущей ячейки
dVal = Col.Cells(i).Value * 3 — 1
‘ Команда ниже копирует результат в колонку А
‘ текущего активного листа — без уточнения названия активного листа
Cells(i, 1) = dVal
i = i + 1
Loop
End Sub
Пример 5
Этот пример макроса приводит пример кода VBA, связанного с событием. Каждый раз, когда человек выделяет ячейку или диапазон значений, связанное с макросом событие активируется.
‘ Код для отображения диалогового окна ячейки B1 текущего листа в случае, если она выбрана
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
‘ Проверка, выбрана ли ячейка B1
If Target.Count = 1 And Target.Row = 1 And Target.Column = 2 Then
‘ При выборе ячейки B1 показать диалоговое окно
MsgBox «You have selected cell B1»
End If
End Sub
Пример 6
Следующая подпрограмма демонстрирует, как обрабатывать ошибки с помощью операторов OnError и Resume. Также в этом коде описывается, как открывать и читать данные с файла.
‘ Подпрограмма, для для установки определенных значений
‘ в ячейках A1 и B1 документа «Data.xls» на диске C:
Sub Set_Values(Val1 As Double, Val2 As Double)
Dim DataWorkbook As Workbook
On Error GoTo ErrorHandling
‘ Открытие документа с данными
Set DataWorkbook = Workbooks.Open(«C:Documents and SettingsData»)
‘ Выбрать переменные Val1 and Val2 с данных в книге Excel
Val1 = Sheets(«Sheet1»).Cells(1, 1)
Val2 = Sheets(«Sheet1»).Cells(1, 2)
DataWorkbook.Close
Exit Sub
ErrorHandling:
‘ Если файл не найден, предложить пользователю найти правильную директорию
‘ после чего продолжить выполнение подпрограммы
MsgBox «Data Workbook not found;» & _
«Please add the workbook to C:Documents and Settings and click OK»
Resume
End Sub
После детального ознакомления с этими примерами будет значительно легче применять свои навыки на практике.
Рекомендации по использованию макросов
Есть несколько рекомендаций, позволяющих значительно увеличить эффективность использования макросов в электронных таблицах:
- Перед тем, как записывать макрос с помощью рекордера, следует заранее продумать все свои действия, поскольку автоматизироваться будут все действия (в том числе, и ошибочные).
- Не стоит торопиться, поскольку паузы при записи макросов не учитываются. Вполне можно начать продумывать по ходу какие-то действия. А все записанные операции будут обработаны в один момент.
- Обязательно необходимо научиться использовать режим отладки макроса. Если возникают какие-то ошибки, он поможет обнаружить, в чем причина неполадки. На первых порах без ошибок не обойтись, потому что в реальной программе будет все не так идеально, как может показаться на первый взгляд.
- Перед использованием макросов, сделанных другими людьми, нужно настроить антивирусную программу на их обнаружение. Как правило, эта опция установлена по умолчанию.
- Если загружаются документы из сомнительных источников, следует выбрать опцию «Отключить макросы» при их открытии. И не рекомендуется менять настройки, которые выставлены по умолчанию в настройках безопасности Excel.
Выводы
Таким образом, макросы – это эффективный инструмент автоматизации рабочих процессов в Excel. Он позволяет автоматизировать даже самые сложные последовательности действий. Если необходимо сделать простую программку, то достаточно воспользоваться встроенной функцией для записи макросов. Для более сложных необходимо освоить язык VBA, который является простым для изучения и очень гибким.
Если используются сторонние макросы, обязательно нужно побеспокоиться о безопасности их использования.
Оцените качество статьи. Нам важно ваше мнение:
Самоучитель по Excel VBA
Смотрите такжеSamir_Baku и правила, конечно, приходится делать с кликом. Или нужноОткройте рабочую книгу Excel, для выполнения всех создавать качественные макропрограммы знать язык программирования ниже действия. с просроченными счетами. импорта данных изView Macros данных, при этом— для расчётаНачиная с этого момента,
Вам не требуетсяДанный учебник является введением: Супер справочник, мне придётся запомнить. помощью макросов, но одновременно создать сразу в которой необходимо этих функций, в автоматически: «VBA» чтобы создаватьВыберите Для этого можно него тоже можно(Макросы). макрос остался записан. этого значения необходимо ВСЕ Ваши действия знание языков программирования. в язык программирования как раз такойНу, это как я в них определенное количество копий использовать макрос: «РАЗРАБОТЧИК»-«Код»-«Visual том числе открытиеПрисваивайте макросам короткие, но
- свои макро-программы с
- Excel создать и выполнить
- записать в макрос:
- В открывшемся диалоговом окне Нам нужно сохранить
- взять именно исходные
- с документом записываются:
- Вам уже любопытно, что Excel VBA (Visual
- нужен! Спасибо вам научиться ездить на
- полный «дундук». Даже определенного рабочего листа.
- Basic». Или нажмите
- и соединение всех
содержательные имена. Когда помощью инструмента записи> макрос, который быстро
Откройте файл шаблона, в мы увидим строку
книгу, как шаблон
данные таблицы. Если
изменения ячеек, пролистывание
office-guru.ru
Как автоматизировать рутинные задачи в Excel с помощью макросов
- такое макрос, и
- Basic for Applications). Алексей!
- автомобиле: нужно знать,
- те макросы которые Список потребностей пользователей
- комбинацию горячих клавиш листов в одну
вы войдете вкус, макросов.Параметры применяет такое форматирование котором мы сохранили с именем нашего Excel с поддержкой взять среднее значение таблицы, даже изменение как он работает? Изучив VBA, ВыЯ здесь давно, что он может я нашел здесь в автоматизации процессов ALT+F11. комбинированную таблицу.
со временем вамСначала надо включить панель> к выделенным ячейкам. макрос — макроса макросов, который имеет из средних по размера окна.
Что такое Макрос?
Тогда смелей вперёд сможете создавать макросы просто сейчас зарегистрировался. делать, какая финтифлюшечка на форуме и работы можно продолжатьПеред началом работы вИспользуйте кнопки со стрелками придется создавать много разработчика. Для этогоЛента и панельWindows macOS FormatDataFormatData расширение отдельным строкам, тоExcel сигнализирует о том, – далее мы и выполнять вAlex_ST для какого действия вообще на «планете» до бесконечности. редакторе следует сделать
для управления курсором макросов. При выборе в меню «Файл».Действия перед записью макроса.. Выберите его и
- XLTM
- результат будет другим. что включен режим шаг за шагом
- Excel практически любые: Да мне особо предназначена, основные правила (которые мне написали
- Если бы не было
- простую настройку. Выберите (Ctrl + Up, в диалоговом окне
Создание макроса – практический пример
открываем группу опцийВ категории Создайте новый макрос с нажмите.=MIN(N2:N21) записи макроса в проделаем весь процесс задачи. Вы очень не за что… эксплуатации (ну и другие участники форума, возможности создавать макросы
инструмент в редакторе и т.п.). Позиционируйте их легче найти «Параметры». В появившемсяНастроить лентуМакросы и средства VBA именемRunВажный момент!или
двух местах. Во-первых, создания макроса вместе скоро поймёте, чтоГлавный респект - движения тоже, конечно, ОГРОМНОЕ ИМ СПАСИБО!), во всех программах,
Visual Basic: «Tools»-«Options». курсор, так чтобы с короткими и окне «Параметры Excel»в списке
находятся на вкладкеLoadData(Выполнить).Если Вы сохраните=МИН(N2:N21) в меню
с Вами. макросы могут сэкономить его составителю, господину не помешало бы, я могу использовать входящих в пакет И на вкладке вы могли добавить, содержательными названиями. Система открываем группу «НастройкаОсновные вкладкиРазработчик.
Когда макрос начнёт работать, файл с расширением=MAX(O2:O21)MacrosМакрос в Microsoft Office уйму времени благодаря А.Климову но ПДД - только так как MS Office. То «Editor» активируйте опцию изменить или удалить VBA предоставляет вам ленты». Обратите вниманиеустановите флажок, которая по умолчаниюВ процессе записи макроса Вы увидите, какXLTX
или(Макросы) – вместо (да, этот функционал автоматизации повторяющихся задачЯ, правда не это в программировании
они написаны изначально, множество операций в «Require Variable Declaration». данные внутри таблицы возможность указать описание на правую колонкуРазработчик скрыта, поэтому сначалаLoadData
- табличный курсор прыгает, то макрос в=МАКС(O2:O21)
- строки работает одинаково во и обеспечить гибкое
- помню точно, откуда как комментарии и а вот редактировать
- процессе рутинной работы Это позволит реализовать по мере необходимости.
- к имени. Обязательно настроек под аналогичным, а затем нажмите
нужно включить ее.сделайте импорт данных с ячейки на нём работать не=MEDIAN(B2:K21)Record Macro
многих приложениях пакета взаимодействие с другими я это скачал, осмысленные имена программ
и подладить под пользователям приходилось бы автоматическое заполнение инструкцийИспользование мыши для навигации используйте ее.
названием «Настройка ленты».
- кнопку Дополнительные сведения см. из файла
- ячейку. Через несколько будет. Кстати, можноили(Запись макроса…) появилась Microsoft Office) – пользователями. но, т.к. скачано и переменных: желательно, себя уже не выполнять вручную (выделять Options Explicit в
- является более сложнымИмя макроса обязательно должно В ней следует
- Сохранить в статье Отображениеdata.csv
- секунд с данными сохранить книгу как=МЕДИАНА(B2:K21) строка это программный кодЭтот учебник не является достаточно давно, то
но не обязательно могу. через одну строку начале каждого ново и не так начинаться с букв отметить галочкой опцию. вкладки «Разработчик».– как мы будут проделаны те шаблон Excel 97-2003,— считаем, используяStop Recording на языке программирования исчерпывающим руководством по есть подозрение, что :-)Хочется хоть как-то кликая по каждому созданного кода. А надежным в момент
и не может «Разработчик» как показаноЗапись макроса
- Запись макроса
- это делали в
- же операции, что
который имеет формат исходные данные таблицы,
(Остановить запись).Visual Basic for Applications
языку программирования Excel по ссылке из
Не плохо просмотреть разобраться что это второму заголовку мышкой в поле ввода
записи. Когда дело содержать пробелы, символы ниже на рисунке: предыдущей части урока. и при записиXLT по причине указаннойВо-вторых, в нижнем левом(VBA), сохранённый внутри VBA. Его цель одного из форумов какие-нибудь видео-курсы. Вот, за зверь такой или копировать вставлять «Tab Width:» укажите
доходит до макросов, или знаки препинания.Теперь нам доступна наНа вкладкеВ группеКогда импорт будет завершён, макроса. Когда всё, он тоже поддерживает выше. углу окна Excel. документа. Чтобы было – помочь начинающему
по Access’y. например, вполне приличные: макрос. по одному листу). значение 2 вместо использовать мышь лучше После первого символа, ленте новая закладкаРазработчикКод остановите запись макроса.
будет готово, таблица макросы.Теперь, когда с вычислениями Иконка понятнее, документ Microsoft специалисту освоить написаниеА объектные моделиУ меня естьЕсли я прочитаю Ручная работа в 4-х. Это позволит только для вызова вы можете использовать
«Разработчик» со всеминажмите кнопку
Выполнение макроса в Excel
на вкладкеУдалите все данные из должна выглядеть такКогда шаблон сохранён, можно закончили, займёмся форматированием.Стоп Office можно сравнить
- макросов в Excel
- Access и Excel хорошиу справочник пр
книгу «Профессиональное программирование лучшем случаи приводить уменьшить ширину кода. меню. больше букв, цифр своими инструментами дляЗапись макросаРазработчик ячеек. же, как и спокойно закрыть Excel. Для начала для(маленький квадратик) указывает со страницей HTML, при помощи кода
естественно, имеют существенные VBA функциям в на VBA в к потере огромного Данная настройка редактораДержите ваши макросы для или нижнее подчеркивание, автоматизации работы в.нажмите кнопкуСохраните файл, как шаблон оригинал, который мыПрежде чем раскрыть все всех ячеек зададим на то, что тогда макрос – VBA. Для желающих различия. Также и формате .chm, сейчас Excel 2002″, я количества времени, а
распространяется на все небольших специфичных задач. но максимальная длина Excel и созданияЕсли необходимо, заполните поляЗапись макроса Excel с поддержкой
форматировали вручную, только возможности созданного Вами одинаковый формат отображения включен режим записи это аналог Javascript. изучить этот язык
одинаковые элементы управления приложу, но он хоть как-то смогу в худшем – листы, но в Чем больше программный имени составляет 80 макросов.Имя макроса
. макросов (расширение XLTM). с другими данными макроса, считаю правильным данных. Выделите все макроса. Нажатие на То, что Javascript программирования более глубоко имеют некоторые одинаковые
весит 138к, модераторы разобраться. Или может ведет к ошибкам границах одной рабочей код в макросе, символов.Макросы – это внутренние,Если необходимо, заполните поляТаким образом, запустив этот в ячейках. обратить внимание на ячейки на листе, неё остановит запись. умеет делать с существуют отличные книги свойства, называющиеся по-разному,
Заглянем под капот: Как работает макрос?
могут и удалить… начать с чего-то или даже потере книги. тем медленнее онАбсолютный адрес ячейки – приложения, которые берутСочетание клавишИмя макроса шаблон, Вы получаетеКак уже не раз пару важных моментов, для этого воспользуйтесь И наоборот, когда
данными в формате по Excel VBA. т.к. отражают специфическуюГлавное — на по проще, что-нибудь ценных данных.Выберите инструмент: «Insert»-«Module» чтобы работает, особенно если это точное местонахождение на себя всюи, доступ к двум
упоминалось, макрос — касающихся макросов в комбинацией клавиш режим записи не HTML, находящимися на Далее приведено содержание «заточку» под объектную первых порах уйти типа «… программированиеВозможность создавать макросы и создать новый стандартный это требуется для курсора, когда информация рутинную работу, облегчаяОписаниеСочетание клавиш макросам – один это программный код целом:Ctrl+A включен, в этом
Добавим ещё один шаг к нашей задаче…
web-странице, очень похоже самоучителя по Excel модель приложения. от общения с на VBA для автоматизировать рабочие процессы модуль для макросов. выполнения многих функций о его размещении жизнь пользователю. Каждый, а затем нажмитеи загружает данные, другой на языке программированияМакрос может нанести вред., либо щелкните по месте находится иконка
- на то, что Visual Basic. ДляНапример в Excel объектами самого Ёкселя чайников…»
- бережет вашу работу В появившемся окне или рассчитать много записывается в макро-адреса
- пользователь может создать кнопкуОписание их форматирует.Visual Basic for ApplicationsЕщё раз прочти предыдущий иконке для включения записи
- макрос может делать начинающих программистов настоятельно
- свойство Combobox1.ListFillRange - (это сложнее), необходимо
- Спасибо. от лишних потерь модуля под текстом
формул в большой с жесткой привязкой макрос без знанияOK, а затем нажмитеЕсли есть желание заняться
(VBA). Когда Вы пункт.Выделить все макроса. Нажатие на с данными в рекомендуется начать с это то же освоить методы простогоGuest времени и возникновения
Option Explicit введите электронной таблице.
к конкретной ячейке
языков программирования. Для
, чтобы начать запись
office-guru.ru
Краткое руководство: создание макроса
кнопку программированием, Вы можете включаете режим записиVBA-код обладает очень большими, которая находится на неё даст тот документе Microsoft Office. первого раздела учебника самое, что в ввода-вывода — работу: Сам это читаю: ошибок. Далее рассмотрим, следующий код макроса:Если вы запустите каждый в момент записи. этого существует макрорекодер, макроса.OK объединить действия этих макроса, Excel фактически возможностями. В частности,
пересечении заголовков строк же результат, чтоМакросы способны выполнить практически и изучать их Access свойство Combobox1.RowSource с MsgBox, InputBox,Помагает =) как создать макрос,Sub MyMakros() процесс отдельно, вы Абсолютные адреса ограничивают который запускается сВыполните действия, которые нужно, чтобы начать запись двух макросов в
записывает каждое сделанное он может выполнять и столбцов. Затем и включение записи любые действия в по порядку. Те, (ведь в Access Immediate Window, Debug.Print.Serge который безошибочно иDim polzovatel As можете быстро просмотреть
возможности макроса, если
Процедура
|
помощью кнопки «Запись автоматизировать, например ввод макроса. один – просто Вами действие в операции с файлами нажмите через меню. документе, которые Вы кто имеет опыт нет объекта Range, |
|
Тогда ставьте себе: Читаю
|
|
(Формат с разделителями) макроса включен, давайте Вот некоторые из VBA, могут сразу данных для листа задачу. Если алгоритм не помогает :((( клик мышкой. Так DateЕсли нельзя разбить длинный листе Excel или действия пользователя макрорекодерНа вкладке стандартного текста илив начало кода Excel пишет программный может удалять или на вкладке займёмся нашей задачей. них (очень малая же перейти к назван по другому). — не линейный,Один уважаемый форумчанин же рассмотрим вpolzovatel = Application.UserName |
Дальнейшие действия
-
макрос на короткие список данных будет в Excel записывает,Разработчик
-
заполнение столбца данных.FormatData код вместо Вас.
Процедура
|
изменять любые файлыHome Первым делом, добавим часть): интересующим темам.Поэтому в приложении нарисуйте его на (The Prist) при каких местах рабочейdata_segodnya = Now приложения, а требуется
|
|
средства не привязывают программирования VBA-код в
|
|
Отлаживайте.Склонен ему верить…. макросы. Как их polzovatel & vbNewLine клавишу F8 каждый адресу ячейки. завершения записи мыОстановить записьОстановить записьИсточник: http://www.howtogeek.com/162975/geek-school-learn-how-to-use-excel-macros-to-automate-tedious-tasks/Macros запускайте и разрешайте строк: формулы в соответствии данными. Часть 3: Массивы применять осторожно.Alex_STvikttur запустить и выполнить, & data_segodnya раз, когда выПо умолчанию в Excel получаем готовую программу, |
Дальнейшие действия
..Перевел: Антон Андронов(Макросы) на вкладке выполнение макросов толькоЖирное начертание шрифта.
support.office.com
Как работать с макросами в Excel 2010 без программирования кода
с названиями заголовковИспользовать внешние источники данныхЧасть 4: Процедуры FunctionГлавное, чтобы модераторы: блин…: Читаю там, читаю а также какEnd Sub хотите перейти к включен режим «Абсолют», которая сама выполняет
Более подробное изучение макросаБолее подробное изучение макросаАвтор: Антон АндроновView из источников, которымВыравнивание по центру. (даны варианты формул
(файлы баз данных, и Sub подольше не удалялиобещанный файл не сям. В основном их максимально оптимизироватьНажмите на кнопку в следующему шагу выполнения но вы можете те действия, которые Примечание:(Вид) кликнуть Вы доверяете.
Заливка цветом. для англоязычной и текстовые документы иЧасть 5: Условные операторы файлик с весом приаттачил то, что нужно
Применение VBA и макросов в Microsoft Excel
под свои потребности. редакторе «Run Macro» задачи. Процесс выполнения изменить его, включив выполнял пользователь приПри редактировании макроса можноПри редактировании макроса можно Мы стараемся как можноView MacrosЧтобы запустить наш макрос,И, наконец, настроим формат русифицированной версии Excel,
т.д.)Часть 6: Циклы в 125К. ПустьNickolaDed в данный моментExcel предоставляет большой и или клавишу F5 программы останавливается, когда кнопку «Относительные ссылки» записи. немного изучить язык немного изучить язык
оперативнее обеспечивать вас(Макросы) и в форматирующий данные, откройте
- итоговых значений. адреса ячеек –
- Создавать новый документ.Часть 7: Операторы и побольше народу скачает,
- : Grant, общие принцепы для решения конкретной изобильный арсенал инструментов на клавиатуре. В
- он видит ошибку. расположенную ниже подКак записать готовый макрос программирования Visual Basic. программирования Visual Basic. актуальными справочными материалами открывшемся диалоговом окне файл шаблона, который
Вот так это должно всегда латинские буквыПроделывать все вышеперечисленные действия встроенные функции попользуется. программирования закладываються в задачи или для для хранения и появившемся окне «Macros» Вы можете исправить кнопкой «Запись макроса» в Excel? Очень
Чтобы изменить макрос, на
Как работать с макросами в Excel
Чтобы изменить макрос, в на вашем языке. нажать мы создали в выглядеть в итоге: и цифры): в любой ихЧасть 8: Объектная модель
1 Правильные имена в макросах.
Hugo школе в 10-11 разбора простого примера. обработки огромного количества нажмите на кнопку ошибку, которую легко на панели инструментов просто: вкладке группе Эта страница переведенаEdit первой части этогоЕсли Вас все устраивает,
=SUM(B2:K2) комбинации. Excel: У меня тоже классе, когда изучаеться Читать просто так, информации с данными. «Run», чтобы посмотреть найти с помощью вкладки «Разработчик»:На вкладке «Разработчик» нажимаемразработчик
2 Используйте относительные (не абсолютные) адреса ячеек
Код автоматически, поэтому ее(Изменить). урока. Если у остановите запись макроса.илиДля примера возьмём самыйЧасть 9: События в давно этот файл Basic или Pascal, как книгу, не Хотя для самой результат работы макроса. «отладки» или записатьАбсолютный отсчет ячеек, всегда кнопку «Запись макроса».нажмите кнопку Макросына вкладке
текст может содержатьОткроется окно Вас стандартные настройкиПоздравляем! Вы только что=СУММ(B2:K2) обычный файл Excel есть. У него на этом этапе
3 Всегда начинайте запись с курсором в A1
имеет смысла. Только универсальной аналитической программыПримечание. Если в главном по-новому. ведется с исходногоВ появившимся диалоговом окне , выберите имяРазработчик неточности и грамматическиеVisual Basic for Applications безопасности, то при самостоятельно записали свой=AVERAGE(B2:K2)CSVЧасть 10: Ошибки VBA есть одна фишка формируеться самое важное, разбор или реализация Excel – хранение меню отсутствует закладкаКаждый пользователь сталкивался с положения (адрес ячейки заполняем параметры макроса. макроса и нажмитенажмите кнопку
ошибки. Для нас, в котором мы открытии файла сверху первый макрос вили. Это простая таблицаПримеры по VBA — на моём это мышление(логическое и практических задач. Обалденная данных само по «РАЗРАБОТЧИК», тогда ее тем, что иногда А1) – до И нажимаем «ОК». кнопку
4 Всегда перемещаться с клавиш направления в момент записи макроса
Макросы важно, чтобы эта увидим программный код над таблицей появится Excel.=СРЗНАЧ(B2:K2) 10х20, заполненная числамиБолее подробное описание по рабочем компе не
последовательное), которое помогает практика здесь, на себе менее интересно, необходимо активировать в в Excel не адреса курсора сПосле завершения нажимаем наизменить, выделите имя макроса
5 Создавайте макросы для конкретных небольших задач
статья была вам записанного нами макроса. предупреждение о том,Чтобы использовать созданный макрос,=MIN(B2:K2) от 0 до Excel VBA можно работает. Оглавление есть, тебе в дальнейшем форуме. Кто не чем возможность их
настройках: «ФАЙЛ»-«Параметры»-«Настроить ленту». найти подходящих инструментов, вашими данными. Если кнопку «Остановить запись»,. Откроется редактор Visual
и нажмите кнопку полезна. Просим вас Да, Вы правильно что запуск макросов нам нужно сохранитьили 100 с заголовками найти на сайте содержание не открывается. понять чего ты ленится, за пару обрабатывать, структурировать и В правом списке которые бы соответствовали вы сохранили ваш после чего макрос Basic.
exceltable.com
Как написать макрос в Excel на языке программирования VBA
Изменить уделить пару секунд поняли, здесь этот отключен, и кнопка, документ Excel в=МИН(B2:K2) для столбцов и Microsoft Office. Дома всё в хочешь и как месяцев вырастает над анализировать с презентацией «Основные вкладки:» активируйте потребностям. При всем макрос в книге будет автоматически сохранен.
Написание макросов в Excel
Обратите внимание на то,. Запустится редактор Visual и сообщить, помогла код можно изменить чтобы включить их формате, который поддерживает=MAX(B2:K2) строк. Наша задачаУрок подготовлен для Вас порядке. ты это можешь
собой до неузнаваемости в отчетах. Для галочкой опцию «Разработчик» изобилии возможностей Excel личных макросов (рекомендуется
Для выполнения или редактирования
- как в нем Basic. ли она вам, и даже создать выполнение. Так как макросы. Для начала
- или превратить этот набор командой сайта office-guru.ruПочему — не реализовать. А уже :) этих целей служит и нажмите на иногда нельзя автоматизировать так и делать), записанного макроса нажимаем выглядят записанные действия.Обратите внимание на то, с помощью кнопок новый макрос. Те шаблон мы сделали необходимо удалить все=МАКС(B2:K2) данных в презентабельноИсточник: http://www.excelfunctions.net/Excel-VBA-Tutorial.html вникал. далее ты начинаешьSerge
- сильнейший аналитических инструмент кнопку ОК. решения некоторых задач, то вы можете на кнопку «Макросы» Возможно, часть кода как в нем
внизу страницы. Для
действия, которые мы самостоятельно и себе
данные из созданной=MEDIAN(B2:K2)
отформатированную таблицу и
Перевел: Антон Андронов
Alex_ST спрашивать, вот я: Виктор, чё-то не по обработке данных
- ведь совершенству нет использовать свою программу (или комбинацию клавиш будет понятной. выглядят записанные действия. удобства также приводим совершали с таблицей мы доверяем, то
нами таблицы, т.е.или сформировать итоги вАвтор: Антон Андронов: Наверное, какая-то защита хочу сделать, допустим видно макросов made такой как «СводныеМакросы позволяют автоматизировать процессы предела. Идеальное решение
на других листах
Возможности макросов в Excel
ALT+F8). Появится окноИзмените код, закройте редактор Возможно, часть кода ссылку на оригинал в этом уроке, нажимаем кнопку сделать из неё=МЕДИАНА(B2:K2) каждой строке.Что такое Макрос? стоит чтобы программизмом
выборку, это можно by vikttur, serge таблицы». Но и работы с документами
– это предоставление с аналогичными данными. со списком записанных Visual Basic и будет понятной. (на английском языке). вполне можно записатьEnable Content пустой шаблон. ДелоТеперь выделите ячейки сКак уже было сказано,Создание макроса – практический дома занимался, а сделать через циклы 007 или Саша… его можно еще
и не только… возможности пользователю самому Независимо от того, макросов и кнопками запустите макрос повторно.Измените код, закройте редакторДля автоматизации часто выполняемых с помощью автоматической(Включить содержимое). в том, что формулами и скопируйте макрос – это пример не на работе или по средствамЛенимся? более усовершенствовать с Они могут практически создавать свои специфические где ваш курсор для управления ими. Посмотрите, что произойдет.
Visual Basic и в Microsoft Excel записи макроса вСледующим шагом, мы импортируем в дальнейшем, работая их во все код, написанный наВыполнение макроса в Excel:-) встроенных функций вvikttur помощью макросов. И одновременно выполнить тысячи инструменты. Для этого позиционируется, когда выС помощью макропрограмм можноУзнайте о том, как запустите макрос повторно. задач можно записать Excel. Но более
последний обновлённый набор с этим шаблоном, строки нашей таблицы, языке программирования VBA.Заглянем под капот: КакGuest том или ином: Я — да. тогда возможности сводных инструментов за одну были созданы макросы. начинаете запись макроса! увеличить производительность труда создавать и запускать Посмотрите, что произойдет. макрос. Макрос представляет сложные макросы, с данных из файла мы будем импортировать потянув за маркер Но в Excel работает макрос?: Смотрел… Познавательно =) языке и ищишьSerge
exceltable.com
Как научится писать макросы?
таблиц не знают операцию (даже по
Код макроса Excel написанный Даже если он пользователя в десятки макросы. Дополнительные сведенияДополнительные сведения о создании собой действие (или тонко настроенной последовательностьюCSV в него самые автозаполнения. Вы можете создатьДобавим ещё один шагSerge лучшие варианты! Спрашиваешь: Та же беда границ. одному клику мышкой). на языке Visual уже находится в раз. Но чтобы см. в статье макросов см. в набор действий), которое и логикой действий(на основе такого свежие и актуальныеПосле выполнения этого действия программу, не написав к нашей задаче…: Здесь у форумчан, предлагаешь :)
grant84 Таким образом расширяются Basic for Application ячейке A1, ваш
использовать запись пользовательских Создание, выполнение, изменение статье Создание и можно выполнять любое требуют программирования вручную. файла мы создавали данные. в каждой строке и строчки кода,Excel располагает мощнейшей, новыкладывал ещё один
свой вариант они
Alex_ST: Здравствуйте уважаемые планетяне.
возможности работы с
(VBA), а его первый макрос лучше
макросов на все и удаление макроса.
удаление макросов. количество раз. ПриПредставьте, что наш исходный наш макрос).
Чтобы очистить все ячейки
должны появиться соответствующие что мы и в то же справочник. тебе свой если: Ребята, если выПо роду деятельности программой. выполняет инструмент приложения, записывать после нажатия 100% следует соблюдатьМакросы позволяют существенно расширитьСведения о запуске макросов создании макроса записываются файл с даннымиПри выполнении импорта данных от данных, щёлкните итоговые значения. сделаем прямо сейчас.
время очень редкоПосмотрите, может пригодится. есть более эффективный. хоть когда-нибудь на мне приходится обрабатывать
Читайте также: Как работать
к которому он клавиш должны быть
простые правила, которые возможности в программе см. в статье
щелчки мышью иdata.csv из CSV-файла, возможно, правой кнопкой мышиДалее, мы подведем итогиЧтобы создать макрос, откройте используемой, возможностью создавать
Alex_STслэн чём-нибудь программировали, то большие объемы цифр с макросами в присоединен. Большинство этих Ctrl + Home. существенно влияют на Excel. Они автоматизируют Запуск макроса.
нажатия клавиш. Послесоздаётся автоматически каким-то Excel попросит Вас по иконке для всей таблицы,View автоматически выполняющиеся последовательности: Бегло просмотрел…: начинал с чтения должны представлять себе и без excel Excel 2010 без инструментов не доступноПример: Представьте себе, что их качество в рабочие процессы иДействия перед записью макроса
создания макроса его процессом и сохраняется настроить некоторые параметры
Выделить все для этого делаем(Вид) > действий с помощьюВроде ничего так справки — хватило общие принципы построения
тут не обойтись. программирования кода на уровне окна каждый месяц вы момент записи и берут большую часть можно отредактировать, чтобы на диске всегда
для правильной передачи, которая находится на ещё несколько математическихMacros макросов. Макрос – справочник. Может пригодиться на написание макроса алгоритмов программ.
Однако операции воС помощью макросов пользователь
программы Excel. Как получаете десятки таблиц
эффективность при выполнении. рутинной работы пользователяУбедитесь в том, что изменить выполняемые им в одном и данных в таблицу. пересечении заголовков строк действий:(Макросы) > идеальный выход, если когда-нибудь. Сохраню себе по утыриванию пароляПоверьте, VB(А) на многом похожи друг может сам создать написать макрос. из всех филиалов. на себя. Просто на ленте отображается действия. том же месте.Когда импорт будет закончен, и столбцов, иСоответственно:Record Macro Вы имеете дело в «копилку» на у начальника :)
среднем уровне - на друга и свой инструмент, которогоТеперь продемонстрируем на примере От вас требуется5 простых советов, которые
нужно научится пользоваться вкладкаДопустим, что необходимо каждый
Например, зайдите в меню из контекстного меню
=SUM(L2:L21)(Запись макроса…) с однотипной задачей, всякий случай.потом прочитал уокенбаха
это очень просто. появляется желание некоторые
ему недостает в информацию о том, организовать данные и
помогут в создании макросами и производительностьРазработчик
месяц создавать отчетC:Datadata.csvMacros выберите пунктилиДайте своему макросу имя которая повторяется множествоСпасибо, Серж. — сильно продвинуло,
Есть набор общих из них автоматизировать. арсенале программы Excel. как писать, редактировать рассчитать показатели, чтобы макросов без программирования. труда возрастет в. По умолчанию вкладка для главного бухгалтера.– путь к
(Макросы) на вкладкеDelete=СУММ(L2:L21) (без пробелов) и раз. Например, обработкаGuest совершенствуюсь на форуме.. для всех языков Некоторые требования можно Например, когда нужно
и выполнять код произвести еще один Воспользуйтесь этими простыми десятки раз!Разработчик
Требуется выделить красным файлу с обновляемымиView(Удалить).=AVERAGE(B2:K21) нажмите
данных или форматирование: В этом видеокурсеps правда до программирования простейших функций, удовлетворить с помощью автоматически выделить каждую макроса. ежемесячный отчет. Вы советами, которые позволяютВам даже не нужноне видна, поэтому
цветом и полужирным данными. Процесс открытия
(Вид) и выберитеТеперь наш лист полностьюилиОК документов по стандартизированному
есть ответ на
этого программировал на операторов и правил.
формул, но не вторую строку одним
Чтобы написать макрос: можете записать макрос
быстро и просто
быть программистом и необходимо выполнить указанные
шрифтом имена клиентов этого файла и команду очищен от всех=СРЗНАЧ(B2:K21)
.
шаблону. При этом многие вопросы с++.. Эти функции, операторы
planetaexcel.ru
все. Кое что
Время на прочтение
7 мин
Количество просмотров 311K
Приветствую всех.
В этом посте я расскажу, что такое VBA и как с ним работать в Microsoft Excel 2007/2010 (для более старых версий изменяется лишь интерфейс — код, скорее всего, будет таким же) для автоматизации различной рутины.
VBA (Visual Basic for Applications) — это упрощенная версия Visual Basic, встроенная в множество продуктов линейки Microsoft Office. Она позволяет писать программы прямо в файле конкретного документа. Вам не требуется устанавливать различные IDE — всё, включая отладчик, уже есть в Excel.
Еще при помощи Visual Studio Tools for Office можно писать макросы на C# и также встраивать их. Спасибо, FireStorm.
Сразу скажу — писать на других языках (C++/Delphi/PHP) также возможно, но требуется научится читать, изменять и писать файлы офиса — встраивать в документы не получится. А интерфейсы Microsoft работают через COM. Чтобы вы поняли весь ужас, вот Hello World с использованием COM.
Поэтому, увы, будем учить Visual Basic.
Чуть-чуть подготовки и постановка задачи
Итак, поехали. Открываем Excel.
Для начала давайте добавим в Ribbon панель «Разработчик». В ней находятся кнопки, текстовые поля и пр. элементы для конструирования форм.
Появилась вкладка.
Теперь давайте подумаем, на каком примере мы будем изучать VBA. Недавно мне потребовалось красиво оформить прайс-лист, выглядевший, как таблица. Идём в гугл, набираем «прайс-лист» и качаем любой, который оформлен примерно так (не сочтите за рекламу, пожалуйста):
То есть требуется, чтобы было как минимум две группы, по которым можно объединить товары (в нашем случае это будут Тип и Производитель — в таком порядке). Для того, чтобы предложенный мною алгоритм работал корректно, отсортируйте товары так, чтобы товары из одной группы стояли подряд (сначала по Типу, потом по Производителю).
Результат, которого хотим добиться, выглядит примерно так:
Разумеется, если смотреть прайс только на компьютере, то можно добавить фильтры и будет гораздо удобнее искать нужный товар. Однако мы хотим научится кодить и задача вполне подходящая, не так ли?
Кодим
Для начала требуется создать кнопку, при нажатии на которую будет вызываться наша програма. Кнопки находятся в панели «Разработчик» и появляются по кнопке «Вставить». Вам нужен компонент формы «Кнопка». Нажали, поставили на любое место в листе. Далее, если не появилось окно назначения макроса, надо нажать правой кнопкой и выбрать пункт «Назначить макрос». Назовём его FormatPrice. Важно, чтобы перед именем макроса ничего не было — иначе он создастся в отдельном модуле, а не в пространстве имен книги. В этому случае вам будет недоступно быстрое обращение к выделенному листу. Нажимаем кнопку «Новый».
И вот мы в среде разработки VB. Также её можно вызвать из контекстного меню командой «Исходный текст»/«View code».
Перед вами окно с заглушкой процедуры. Можете его развернуть. Код должен выглядеть примерно так:
Sub FormatPrice()End Sub
Напишем Hello World:
Sub FormatPrice()
MsgBox "Hello World!"
End Sub
И запустим либо щелкнув по кнопке (предварительно сняв с неё выделение), либо клавишей F5 прямо из редактора.
Тут, пожалуй, следует отвлечься на небольшой ликбез по поводу синтаксиса VB. Кто его знает — может смело пропустить этот раздел до конца. Основное отличие Visual Basic от Pascal/C/Java в том, что команды разделяются не ;, а переносом строки или двоеточием (:), если очень хочется написать несколько команд в одну строку. Чтобы понять основные правила синтаксиса, приведу абстрактный код.
Примеры синтаксиса
' Процедура. Ничего не возвращает
' Перегрузка в VBA отсутствует
Sub foo(a As String, b As String)
' Exit Sub ' Это значит "выйти из процедуры"
MsgBox a + ";" + b
End Sub' Функция. Вовращает Integer
Function LengthSqr(x As Integer, y As Integer) As Integer
' Exit Function
LengthSqr = x * x + y * y
End FunctionSub FormatPrice()
Dim s1 As String, s2 As String
s1 = "str1"
s2 = "str2"
If s1 <> s2 Then
foo "123", "456" ' Скобки при вызове процедур запрещены
End IfDim res As sTRING ' Регистр в VB не важен. Впрочем, редактор Вас поправит
Dim i As Integer
' Цикл всегда состоит из нескольких строк
For i = 1 To 10
res = res + CStr(i) ' Конвертация чего угодно в String
If i = 5 Then Exit For
Next iDim x As Double
x = Val("1.234") ' Парсинг чисел
x = x + 10
MsgBox xOn Error Resume Next ' Обработка ошибок - игнорировать все ошибки
x = 5 / 0
MsgBox xOn Error GoTo Err ' При ошибке перейти к метке Err
x = 5 / 0
MsgBox "OK!"
GoTo ne
Err:
MsgBox
"Err!"
ne:
On Error GoTo 0 ' Отключаем обработку ошибок
' Циклы бывает, какие захотите
Do While True
Exit DoLoop 'While True
Do 'Until False
Exit Do
Loop Until False
' А вот при вызове функций, от которых хотим получить значение, скобки нужны.
' Val также умеет возвращать Integer
Select Case LengthSqr(Len("abc"), Val("4"))
Case 24
MsgBox "0"
Case 25
MsgBox "1"
Case 26
MsgBox "2"
End Select' Двухмерный массив.
' Можно также менять размеры командой ReDim (Preserve) - см. google
Dim arr(1 to 10, 5 to 6) As Integer
arr(1, 6) = 8Dim coll As New Collection
Dim coll2 As Collection
coll.Add "item", "key"
Set coll2 = coll ' Все присваивания объектов должны производится командой Set
MsgBox coll2("key")
Set coll2 = New Collection
MsgBox coll2.Count
End Sub
Грабли-1. При копировании кода из IDE (в английском Excel) есь текст конвертируется в 1252 Latin-1. Поэтому, если хотите сохранить русские комментарии — надо сохранить крокозябры как Latin-1, а потом открыть в 1251.
Грабли-2. Т.к. VB позволяет использовать необъявленные переменные, я всегда в начале кода (перед всеми процедурами) ставлю строчку Option Explicit. Эта директива запрещает интерпретатору заводить переменные самостоятельно.
Грабли-3. Глобальные переменные можно объявлять только до первой функции/процедуры. Локальные — в любом месте процедуры/функции.
Еще немного дополнительных функций, которые могут пригодится: InPos, Mid, Trim, LBound, UBound. Также ответы на все вопросы по поводу работы функций/их параметров можно получить в MSDN.
Надеюсь, что этого Вам хватит, чтобы не пугаться кода и самостоятельно написать какое-нибудь домашнее задание по информатике. По ходу поста я буду ненавязчиво знакомить Вас с новыми конструкциями.
Кодим много и под Excel
В этой части мы уже начнём кодить нечто, что умеет работать с нашими листами в Excel. Для начала создадим отдельный лист с именем result (лист с данными назовём data). Теперь, наверное, нужно этот лист очистить от того, что на нём есть. Также мы «выделим» лист с данными, чтобы каждый раз не писать длинное обращение к массиву с листами.
Sub FormatPrice()
Sheets("result").Cells.Clear
Sheets("data").Activate
End Sub
Работа с диапазонами ячеек
Вся работа в Excel VBA производится с диапазонами ячеек. Они создаются функцией Range и возвращают объект типа Range. У него есть всё необходимое для работы с данными и/или оформлением. Кстати сказать, свойство Cells листа — это тоже Range.
Примеры работы с Range
Sheets("result").Activate
Dim r As Range
Set r = Range("A1")
r.Value = "123"
Set r = Range("A3,A5")
r.Font.Color = vbRed
r.Value = "456"
Set r = Range("A6:A7")
r.Value = "=A1+A3"
Теперь давайте поймем алгоритм работы нашего кода. Итак, у каждой строчки листа data, начиная со второй, есть некоторые данные, которые нас не интересуют (ID, название и цена) и есть две вложенные группы, к которым она принадлежит (тип и производитель). Более того, эти строки отсортированы. Пока мы забудем про пропуски перед началом новой группы — так будет проще. Я предлагаю такой алгоритм:
- Считали группы из очередной строки.
- Пробегаемся по всем группам в порядке приоритета (вначале более крупные)
- Если текущая группа не совпадает, вызываем процедуру AddGroup(i, name), где i — номер группы (от номера текущей до максимума), name — её имя. Несколько вызовов необходимы, чтобы создать не только наш заголовок, но и всё более мелкие.
- После отрисовки всех необходимых заголовков делаем еще одну строку и заполняем её данными.
Для упрощения работы рекомендую определить следующие функции-сокращения:
Function GetCol(Col As Integer) As String
GetCol = Chr(Asc("A") + Col)
End FunctionFunction GetCellS(Sheet As String, Col As Integer, Row As Integer) As Range
Set GetCellS = Sheets(Sheet).Range(GetCol(Col) + CStr(Row))
End FunctionFunction GetCell(Col As Integer, Row As Integer) As Range
Set GetCell = Range(GetCol(Col) + CStr(Row))
End Function
Далее определим глобальную переменную «текущая строчка»: Dim CurRow As Integer. В начале процедуры её следует сделать равной единице. Еще нам потребуется переменная-«текущая строка в data», массив с именами групп текущей предыдущей строк. Потом можно написать цикл «пока первая ячейка в строке непуста».
Глобальные переменные
Option Explicit ' про эту строчку я уже рассказывал
Dim CurRow As Integer
Const GroupsCount As Integer = 2
Const DataCount As Integer = 3
FormatPrice
Sub FormatPrice()
Dim I As Integer ' строка в data
CurRow = 1
Dim Groups(1 To GroupsCount) As String
Dim PrGroups(1 To GroupsCount) As String
Sheets(
"data").Activate
I = 2
Do While True
If GetCell(0, I).Value = "" Then Exit Do
' ...
I = I + 1
Loop
End Sub
Теперь надо заполнить массив Groups:
На месте многоточия
Dim I2 As Integer
For I2 = 1 To GroupsCount
Groups(I2) = GetCell(I2, I)
Next I2
' ...
For I2 = 1 To GroupsCount ' VB не умеет копировать массивы
PrGroups(I2) = Groups(I2)
Next I2
I = I + 1
И создать заголовки:
На месте многоточия в предыдущем куске
For I2 = 1 To GroupsCount
If Groups(I2) <> PrGroups(I2) Then
Dim I3 As Integer
For I3 = I2 To GroupsCount
AddHeader I3, Groups(I3)
Next I3
Exit For
End If
Next I2
Не забудем про процедуру AddHeader:
Перед FormatPrice
Sub AddHeader(Ty As Integer, Name As String)
GetCellS("result", 1, CurRow).Value = Name
CurRow = CurRow + 1
End Sub
Теперь надо перенести всякую информацию в result
For I2 = 0 To DataCount - 1
GetCellS("result", I2, CurRow).Value = GetCell(I2, I)
Next I2
Подогнать столбцы по ширине и выбрать лист result для показа результата
После цикла в конце FormatPrice
Sheets("Result").Activate
Columns.AutoFit
Всё. Можно любоваться первой версией.
Некрасиво, но похоже. Давайте разбираться с форматированием. Сначала изменим процедуру AddHeader:
Sub AddHeader(Ty As Integer, Name As String)
Sheets("result").Range("A" + CStr(CurRow) + ":C" + CStr(CurRow)).Merge
' Чтобы не заводить переменную и не писать каждый раз длинный вызов
' можно воспользоваться блоком With
With GetCellS("result", 0, CurRow)
.Value = Name
.Font.Italic = True
.Font.Name = "Cambria"
Select Case Ty
Case 1 ' Тип
.Font.Bold = True
.Font.Size = 16
Case 2 ' Производитель
.Font.Size = 12
End Select
.HorizontalAlignment = xlCenter
End With
CurRow = CurRow + 1
End Sub
Уже лучше:
Осталось только сделать границы. Тут уже нам требуется работать со всеми объединёнными ячейками, иначе бордюр будет только у одной:
Поэтому чуть-чуть меняем код с добавлением стиля границ:
Sub AddHeader(Ty As Integer, Name As String)
With Sheets("result").Range("A" + CStr(CurRow) + ":C" + CStr(CurRow))
.Merge
.Value = Name
.Font.Italic = True
.Font.Name = "Cambria"
.HorizontalAlignment = xlCenterSelect Case Ty
Case 1 ' Тип
.Font.Bold = True
.Font.Size = 16
.Borders(xlTop).Weight = xlThick
Case 2 ' Производитель
.Font.Size = 12
.Borders(xlTop).Weight = xlMedium
End Select
.Borders(xlBottom).Weight = xlMedium ' По убыванию: xlThick, xlMedium, xlThin, xlHairline
End With
CurRow = CurRow + 1
End Sub
Осталось лишь добится пропусков перед началом новой группы. Это легко:
В начале FormatPrice
Dim I As Integer ' строка в data
CurRow = 0 ' чтобы не было пропуска в самом начале
Dim Groups(1 To GroupsCount) As String
В цикле расстановки заголовков
If Groups(I2) <> PrGroups(I2) Then
CurRow = CurRow + 1
Dim I3 As Integer
В точности то, что и хотели.
Надеюсь, что эта статья помогла вам немного освоится с программированием для Excel на VBA. Домашнее задание — добавить заголовки «ID, Название, Цена» в результат. Подсказка: CurRow = 0 CurRow = 1.
Файл можно скачать тут (min.us) или тут (Dropbox). Не забудьте разрешить исполнение макросов. Если кто-нибудь подскажет человеческих файлохостинг, залью туда.
Спасибо за внимание.
Буду рад конструктивной критике в комментариях.
UPD: Перезалил пример на Dropbox и min.us.
UPD2: На самом деле, при вызове процедуры с одним параметром скобки можно поставить. Либо использовать конструкцию Call Foo(«bar», 1, 2, 3) — тут скобки нужны постоянно.