Что такое макросы в excel 2003

  • Статьи

Как включить макросы (разрешить использование макросов) в Excel 2003:

1) В главном меню Excel 2003 нажмите Сервис — Макрос — Безопасность…

Включение макросов в Excel 2003

2) Установите НИЗКИЙ уровень безопасности:

Не бойтесь всех этих предупреждений о макровирусах — их уже давно днем с огнем не сыщешь.
По крайней мере мне, за все годы работы с Excel (я открывал тысячи разных файлов из интернета), попадался всего один макровирус в файле Word, — и то он был нерабочим, да и было это в 2005 году.
С тех пор я ни разу не встречал этих вирусов — их распространение давно закончилось.

Смена уровня безопасности в Excel 2003

3) Перезапустите Excel (полностью его закрыв, и открыв снова)

ВАЖНО: После того, как в настройках Excel вы включили макросы (установили низкий уровень безопасности),
необходимо полностью закрыть Excel, и запустить его заново, — только после этого настройки применятся.

  • 39408 просмотров

Введение

Всем нам приходится — кому реже, кому чаще — повторять одни и те же действия и операции в Excel. Любая офисная работа предполагает некую «рутинную составляющую» — одни и те же еженедельные отчеты, одни и те же действия по обработке поступивших данных, заполнение однообразных таблиц или бланков и т.д. Использование макросов и пользовательских функций позволяет автоматизировать эти операции, перекладывая монотонную однообразную работу на плечи Excel. Другим поводом для использования макросов в вашей работе может стать необходимость добавить в Microsoft Excel недостающие, но нужные вам функции. Например функцию сборки данных с разных листов на один итоговый лист, разнесения данных обратно, вывод суммы прописью и т.д.

Макрос — это запрограммированная последовательность действий (программа, процедура), записанная на языке программирования Visual Basic for Applications (VBA). Мы можем запускать макрос сколько угодно раз, заставляя Excel выполнять последовательность любых  нужных нам действий, которые нам не хочется выполнять вручную.

В принципе, существует великое множество языков программирования (Pascal, Fortran, C++, C#, Java, ASP, PHP…), но для всех программ пакета Microsoft Office стандартом является именно встроенный язык VBA. Команды этого языка понимает любое офисное приложение, будь то Excel, Word, Outlook или Access.

Способ 1. Создание макросов в редакторе Visual Basic

Для ввода команд и формирования программы, т.е. создания макроса необходимо открыть специальное окно — редактор программ на VBA, встроенный в Microsoft Excel.

  • В старых версиях (Excel 2003 и старше) для этого идем в меню Сервис — Макрос — Редактор Visual Basic (Toos — Macro — Visual Basic Editor).
  • В новых версиях (Excel 2007 и новее) для этого нужно сначала отобразить вкладку Разработчик (Developer). Выбираем Файл — Параметры — Настройка ленты (File — Options — Customize Ribbon) и включаем в правой части окна флажок Разработчик (Developer). Теперь на появившейся вкладке нам будут доступны основные инструменты для работы с макросами, в том числе и нужная нам кнопка Редактор Visual Basic (Visual Basic Editor)



    macro1.png:

К сожалению, интерфейс редактора VBA и файлы справки не переводятся компанией  Microsoft на русский язык, поэтому с английскими командами в меню и окнах придется смириться:

macro2.png

Макросы (т.е. наборы команд на языке VBA) хранятся в программных модулях. В любой книге Excel мы можем создать любое количество программных модулей и разместить там наши макросы. Один модуль может содержать любое количество макросов. Доступ ко всем модулям осуществляется с помощью окна Project Explorer в левом верхнем углу редактора (если его не видно, нажмите CTRL+R). Программные модули бывают нескольких типов для разных ситуаций:

  • Обычные модули — используются в большинстве случаев, когда речь идет о макросах. Для создания такого модуля выберите в меню Insert — Module. В появившееся окно нового пустого модуля можно вводить команды на VBA, набирая их с клавиатуры или копируя их из другого модуля, с этого сайта или еще откуда нибудь:

    macro3.png

  • Модуль Эта книга — также виден в левом верхнем углу редактора Visual Basic в окне, которое называется Project Explorer. В этот модуль обычно записываются макросы, которые должны выполнятся при наступлении каких-либо событий в книге (открытие или сохранение книги, печать файла и т.п.):

    macro4.png

  • Модуль листа — доступен через Project Explorer и через контекстное меню листа, т.е. правой кнопкой мыши по ярлычку листа — команда Исходный текст (View Source). Сюда записывают макросы, которые должны выполняться при наступлении определенных событий на листе (изменение данных в ячейках, пересчет листа, копирование или удаление листа и т.д.)

    macro5.png

 Обычный макрос, введенный в стандартный модуль выглядит примерно так:

macro6.png

Давайте разберем приведенный выше в качестве примера макрос Zamena:

  • Любой макрос должен начинаться с оператора Sub, за которым идет имя макроса и список аргументов (входных значений) в скобках. Если аргументов нет, то скобки надо оставить пустыми.
  • Любой макрос должен заканчиваться оператором End Sub.
  • Все, что находится между Sub и End Sub — тело макроса, т.е. команды, которые будут выполняться при запуске макроса. В данном случае макрос выделяет ячейку заливает выделенных диапазон (Selection) желтым цветом (код = 6) и затем проходит в цикле по всем ячейкам, заменяя формулы на значения. В конце выводится окно сообщения (MsgBox).

С ходу ясно, что вот так сразу, без предварительной подготовки и опыта в программировании вообще и на VBA в частности, сложновато будет сообразить какие именно команды и как надо вводить, чтобы макрос автоматически выполнял все действия, которые, например, Вы делаете для создания еженедельного отчета для руководства компании. Поэтому мы переходим ко второму способу создания макросов, а именно…

Способ 2. Запись макросов макрорекордером

Макрорекордер — это небольшая программа, встроенная в Excel, которая переводит любое действие пользователя на язык программирования VBA и записывает получившуюся команду в программный модуль. Если мы включим макрорекордер на запись, а затем начнем создавать свой еженедельный отчет, то макрорекордер начнет записывать команды вслед за каждым нашим действием и, в итоге, мы получим макрос создающий отчет как если бы он был написан программистом. Такой способ создания макросов не требует знаний пользователя о программировании и VBA и позволяет пользоваться макросами как неким аналогом видеозаписи: включил запись, выполнил операци, перемотал пленку и запустил выполнение тех же действий еще раз. Естественно у такого способа есть свои плюсы и минусы:

  • Макрорекордер записывает только те действия, которые выполняются в пределах окна Microsoft Excel. Как только вы закрываете Excel или переключаетесь в другую программу — запись останавливается.
  • Макрорекордер может записать только те действия, для которых есть команды меню или кнопки в Excel. Программист же может написать макрос, который делает то, что Excel никогда не умел (сортировку по цвету, например или что-то подобное).
  • Если во время записи макроса макрорекордером вы ошиблись — ошибка будет записана. Однако смело можете давить на кнопку отмены последнего действия (Undo) — во время записи макроса макрорекордером она не просто возрвращает Вас в предыдущее состояние, но и стирает последнюю записанную команду на VBA.

Чтобы включить запись необходимо:

  • в Excel 2003 и старше — выбрать в меню Сервис — Макрос — Начать запись (Tools — Macro — Record New Macro)
  • в Excel 2007 и новее — нажать кнопку Запись макроса (Record macro) на вкладке Разработчик (Developer)

Затем необходимо настроить параметры записываемого макроса в окне Запись макроса:

macro7.png

  • Имя макроса — подойдет любое имя на русском или английском языке. Имя должно начинаться с буквы и не содержать пробелов и знаков препинания.
  • Сочетание клавиш — будет потом использоваться для быстрого запуска макроса. Если забудете сочетание или вообще его не введете, то макрос можно будет запустить через меню Сервис — Макрос — Макросы — Выполнить (Tools — Macro — Macros — Run) или с помощью кнопки Макросы (Macros) на вкладке Разработчик (Developer) или нажав ALT+F8.
  • Сохранить в… — здесь задается место, куда будет сохранен текст макроса, т.е. набор команд на VBA из которых и состоит макрос.:
    • Эта книга — макрос сохраняется в модуль текущей книги и, как следствие, будет выполнятся только пока эта книга открыта в Excel
    • Новая книга — макрос сохраняется в шаблон, на основе которого создается любая новая пустая книга в Excel, т.е. макрос будет содержаться во всех новых книгах, создаваемых на данном компьютере начиная с текущего момента
    • Личная книга макросов — это специальная книга Excel  с именем Personal.xls, которая используется как хранилище макросов. Все макросы из Personal.xls загружаются в память при старте Excel и могут быть запущены в любой момент и в любой книге.

После включения записи и выполнения действий, которые необходимо записать, запись можно остановить командой Остановить запись (Stop Recording).

Запуск и редактирование макросов

Управление всеми доступными макросами производится в окне, которое можно открыть с помощью кнопки Макросы (Macros) на вкладке Разработчик (Developer) или — в старых версиях Excel — через меню Сервис — Макрос — Макросы (Tools — Macro — Macros):

macro8.png

  • Любой выделенный в списке макрос можно запустить кнопкой Выполнить (Run).
  • Кнопка Параметры (Options) позволяет посмотреть и отредактировать сочетание клавиш для быстрого запуска макроса.
  • Кнопка Изменить (Edit) открывает редактор Visual Basic (см. выше) и позволяет просмотреть и отредактировать текст макроса на VBA.

Создание кнопки для запуска макросов

Чтобы не запоминать сочетание клавиш для запуска макроса, лучше создать кнопку и назначить ей нужный макрос. Кнопка может быть нескольких типов:

Кнопка на панели инструментов в Excel 2003 и старше

Откройте меню Сервис — Настройка (Tools — Customize) и перейдите на вкладку Команды (Commands). В категории Макросы легко найти веселый желтый «колобок» — Настраиваемую кнопку (Custom button):

macro9.gif

Перетащите ее к себе на панель инструментов и затем щелкните по ней правой кнопкой мыши. В контекстом меню можно назначить кнопке макрос, выбрать другой значок и имя:

macro10.gif

Кнопка на панели быстрого доступа в Excel 2007 и новее

Щелкните правой кнопкой мыши по панели быстрого доступа в левом верхнем углу окна Excel и выберите команду Настройка панели быстрого доступа (Customise Quick Access Toolbar):

macro11.png

Затем в открывшемся окне выберите категорию Макросы и при помощи кнопки Добавить (Add) перенесите выбранный макрос в правую половину окна, т.е. на панель быстрого доступа:

macro12.png

Кнопка на листе

Этот способ подходит для любой версии Excel. Мы добавим кнопку запуска макроса прямо на рабочий лист, как графический объект. Для этого:

  • В Excel 2003 и старше — откройте панель инструментов Формы через меню Вид — Панели инструментов — Формы (View — Toolbars — Forms)
  • В Excel 2007 и новее — откройте выпадающий список Вставить (Insert) на вкладке Разработчик (Developer) 

Выберите объект Кнопка (Button):

macro13.png

Затем нарисуйте кнопку на листе, удерживая левую кнопку мыши. Автоматически появится окно, где нужно выбрать макрос, который должен запускаться при щелчке по нарисованной кнопке.

Создание пользовательских функций на VBA

Создание пользовательских функций или, как их иногда еще называют, UDF-функций (User Defined Functions) принципиально не отличается от создания макроса в обычном программном модуле. Разница только в том, что макрос выполняет последовательность действий с объектами книги (ячейками, формулами и значениями, листами, диаграммами и т.д.), а пользовательская функция — только с теми значениями, которые мы передадим ей как аргументы (исходные данные для расчета).

Чтобы создать пользовательскую функцию для расчета, например, налога на добавленную стоимость (НДС) откроем редактор VBA, добавим новый модуль через меню Insert — Module и введем туда текст нашей функции:

macro14.png

Обратите внимание, что в отличие от макросов функции имеют заголовок Function вместо Sub и непустой список аргументов (в нашем случае это Summa). После ввода кода наша функция становится доступна в обычном окне Мастера функций (Вставка — Функция) в категории Определенные пользователем (User Defined):

macro15.png

После выбора функции выделяем ячейки с аргументами (с суммой, для которой надо посчитать НДС) как в случае с обычной функцией:

macro16.png

Microsoft Excel – это популярное для работы с таблицами приложение, используемое в офисах и дом…

Microsoft
Excel – это популярное для работы с
таблицами приложение, используемое в
офисах и домах 90% людей. Несмотря на то
что программе уже 34 года, новые возможности
продолжают добавляться в обновлениях.
Поэтому программа до сих пор популярна.
Чтобы облегчить себе работу, нужно
знать, как работают эти опции. Для начала расскажем о том, что такое
макросы, а потом – как
включить макросы в Excel
2010, 2007, 2003.

Как включить макросы в Excel 2010, 2007, 2003

Что
такое макрос?    

До
того как
включить макросы в Excel,
необходимо
узнать, для чего они нужны. Макросы –
это сохраненные в строках таблицы
заранее созданные последовательности
действий с данными. Реализованы на языке
VBA, что позволяет работать не только с
командами Экселя, но и других приложений
Office, поддерживающих этот язык. Используя
макросы, можно настроить автоматическое
форматирование строк таблицы, отправку
по почте, или создание презентации.

как включить макросы в excel 2010

Описание
параметров макросов

После
сохранения макросы содержат пять
параметров работы, необходимых для
обеспечения защищенности при взаимодействии
с ними, так
как включить макросы в Excel
легко,
а избавляться от вирусов – нет.

  1. Отключить макросы без уведомления.
    Применяется
    для таблиц, автор которых неизвестен.
    Деактивирует сохраненные в ячейках
    макросы, не предупреждая об этом.
    Пользуйтесь им при опасности вирусов
    в таблице.
  2. Отключить макросы с уведомлением.
    Этот
    режим выбран стандартно. Предлагает
    выключать макросы, но перед этим
    запрашивает разрешения пользователя.
    С ним вы сможете решать, оставлять ли,
    или нет отдельно каждый макрос.
  3. Отключить макросы, кроме макросов с
    цифровой подписью.
    Похож
    на предыдущий, но автоматически разрешает
    использование макросов, подписанных
    цифровой подписью предприятия, доверие
    которому вы уже подтвердили.
  4. Включить макросы.
    Из
    названия понятно, что параметр разрешает
    использование макрокоманд, записанных
    в таблицу.
  5. Доверять доступ к объектной модели
    проектов VBA.

как в excel вставить макрос

    Показатель
    для разработчиков, открывающий доступ
    таблицы к программам, написанным для
    модели VBA любого приложения, по желанию
    пользователя. Это позволяет программисту
    настраивать, какой код имеет доступ к
    макросам, и куда макросы могут отправлять
    данные. При этом взломать или повредить
    работу команд программиста практически
    невозможно. Но новичку в VBA лучше не
    использовать этот параметр.

    макросы excel как включить

    Как включить
    макросы в Excel

    Существует
    три версии Экселя, где активация макросов
    отличается друг от друга. Сначала
    рассмотрим, как
    включить макросы в Excel
    2010.

    как вставить макрос в 2010 excel

    Как
    включить макросы в MS
    Excel 2010

    В
    2010 версии Экселя разработчики сделали
    упор на безопасность, поэтому для
    включения макросов нужно сделать
    следующее:

    • В верхнем меню приложения нажмите
      «Файл».
    • Откроется список, выбрать предпоследний
      пункт – «Параметры».
    • Нажмите,
      и попадете в окно «Параметры Excel». Слева
      перейдите в «Центр управления
      безопасностью».

    Как включить макросы в Excel 2010, 2007, 2003

    • Справа в тексте кликните «Параметры…».
    • Откроется еще одно меню, где нужно
      выбрать «Параметры макросов».
    • Отметьте один из пунктов, нажмите «Ок».

    Как включить макросы в Excel 2010, 2007, 2003

    • Закройте и запустите
      Excel снова, для вступления изменений в
      силу.

    Как
    включить макросы в MS
    Excel 2007

    Здесь
    способ не сильно отличается от того,
    как
    включить макросы в Excel
    2010:

    • Нажмите кнопку «Файл» (круглая желтая
      кнопка с цветными квадратами) слева
      сверху окна.
    • В правой нижней части меню кликните на
      «Параметры Excel».

    Как включить макросы в Excel 2010, 2007, 2003

    • Перейдите в раздел «Центр управления
      безопасностью», а затем «Параметры
      центра…»
    • В открывшемся меню отметьте режим работы
      макросов, который нужен.

    Как включить макросы в Excel 2010, 2007, 2003

    • Перезапустите Эксель.

    Как
    включить макросы в MS
    Excel 2003

    2003
    Эксель уступает в безопасности 2010-му,
    и включить макросы в нем легче, но важно
    тщательно проверять файлы на вирусы,
    пользуясь им. Включить исполнение
    макросов можно так:

    1. В
      открытом приложении нажмите на кнопку
      «Сервис» в верхнем меню.
    2. В выпадающем списке нажмите на «Макрос»,
      и «Безопасность».
    3. Откроется меню безопасности, где нужно
      отметить уровень безопасности для
      макросов.
    4. Нажмите
      «Ок», и перезайдите в Эксель.

    Как включить макросы в Excel 2010, 2007, 2003

    Способы

    Включить
    макрокоманды можно одним из трех путей:

    • во
      время показа окна сообщения;
    • с
      помощью Backstage;
    • когда
      появляется предупреждение системы
      безопасности.

    Как включить макросы в Excel 2010, 2007, 2003

    Во
    время показа окна сообщения

    Дополнительный
    способ работает, когда в Экселе открывается
    файл, содержащий макрокоманды. В верхней
    части листа появляется желтая карточка
    с надписью «Предупреждение системы
    безопасности». Кликните по «Включить
    содержимое», и они активируются.

    Как включить макросы в Excel 2010, 2007, 2003

    С
    помощью Backstage

    Если
    открыть книгу с макросами, в меню «Файл»
    появляется сообщение, позволяющее
    активировать их. Для этого сделайте
    следующее:

    1. Раскройте меню «Файл» — левая в ленте
      вверху страницы.
    2. В окне «Предупреждение системы
      безопасности» кликните по «Включить
      содержимое».
    3. Появится диалоговое меню, где необходимо
      будет отметить «Всегда включать активное
      содержимое этого документа».

    Как включить макросы в Excel 2010, 2007, 2003

    После
    того как все получилось, перезагрузите
    приложение.

    Активировать
    на одну сессию при появлении предупреждения
    системы безопасности

    Способ
    включения только на один раз для одной
    книги:

    1. Раскройте меню «Файл» — левая в ленте
      вверху страницы.
    2. В окне «Предупреждение системы
      безопасности» кликните по «Включить
      содержимое».
    3. Перейдите в раздел «Дополнительные
      параметры».
    4. В появившемся поле активируйте пункт
      «Включить содержимое для этого сеанса»
      по очереди для каждого из макросов.
    5. Сохраните изменения, кликнув «Ок».

    Microsoft Excel – это популярное для работы с таблицами приложение, используемое в офисах и домах 90% людей. Несмотря на то что программе уже 34 года, новые возможности продолжают добавляться в обновлениях. Поэтому программа до сих пор популярна. Чтобы облегчить себе работу, нужно знать, как работают эти опции. Для начала расскажем о том, что такое макросы, а потом – как включить макросы в Excel 2010, 2007, 2003.

    Как включить макросы в Excel 2010, 2007, 2003

    Что такое макрос?

    До того как включить макросы в Excel, необходимо узнать, для чего они нужны. Макросы – это сохраненные в строках таблицы заранее созданные последовательности действий с данными. Реализованы на языке VBA, что позволяет работать не только с командами Экселя, но и других приложений Office, поддерживающих этот язык. Используя макросы, можно настроить автоматическое форматирование строк таблицы, отправку по почте, или создание презентации.

    как включить макросы в excel 2010

    Описание параметров макросов

    После сохранения макросы содержат пять параметров работы, необходимых для обеспечения защищенности при взаимодействии с ними, так как включить макросы в Excel легко, а избавляться от вирусов – нет.

    1. Отключить макросы без уведомления. Применяется для таблиц, автор которых неизвестен. Деактивирует сохраненные в ячейках макросы, не предупреждая об этом. Пользуйтесь им при опасности вирусов в таблице.
    2. Отключить макросы с уведомлением. Этот режим выбран стандартно. Предлагает выключать макросы, но перед этим запрашивает разрешения пользователя. С ним вы сможете решать, оставлять ли, или нет отдельно каждый макрос.
    3. Отключить макросы, кроме макросов с цифровой подписью. Похож на предыдущий, но автоматически разрешает использование макросов, подписанных цифровой подписью предприятия, доверие которому вы уже подтвердили.
    4. Включить макросы. Из названия понятно, что параметр разрешает использование макрокоманд, записанных в таблицу.
    5. Доверять доступ к объектной модели проектов VBA.

    как в excel вставить макрос

    Показатель для разработчиков, открывающий доступ таблицы к программам, написанным для модели VBA любого приложения, по желанию пользователя. Это позволяет программисту настраивать, какой код имеет доступ к макросам, и куда макросы могут отправлять данные. При этом взломать или повредить работу команд программиста практически невозможно. Но новичку в VBA лучше не использовать этот параметр.

    макросы excel как включить

    Excel 2003

    Для одной из первых версий 2003 года процесс запуска макрокоманды следующий:

    1. На Панели управления ищете вкладку Сервис, затем из выпадающего списка выбираете строку Макрос и переходите в раздел Безопасность.

    1. Открывается новое диалоговое окно, в котором отображаются уровни безопасности. По умолчанию стоит либо высокая, либо очень высокая степень защиты. При такой настройке запустить подпрограмму практически невозможно. Поэтому ставите галочку напротив самого последнего пункта и нажимаете ОК.

    Открывается новое диалоговое окно

    На заметку! Чтобы изменения окончательно вступили в силу, необходимо закрыть и открыть редактор. Это общее правило для всех поколений Microsoft Office.

    Способы

    Включить макрокоманды можно одним из трех путей:

    • во время показа окна сообщения;
    • с помощью Backstage;
    • когда появляется предупреждение системы безопасности.

    Как включить макросы в Excel 2010, 2007, 2003

    Во время показа окна сообщения

    Дополнительный способ работает, когда в Экселе открывается файл, содержащий макрокоманды. В верхней части листа появляется желтая карточка с надписью «Предупреждение системы безопасности». Кликните по «Включить содержимое», и они активируются.

    Как включить макросы в Excel 2010, 2007, 2003

    С помощью Backstage

    Если открыть книгу с макросами, в меню «Файл» появляется сообщение, позволяющее активировать их. Для этого сделайте следующее:

    1. Раскройте меню «Файл» — левая в ленте вверху страницы.
    2. В окне «Предупреждение системы безопасности» кликните по «Включить содержимое».
    3. Появится диалоговое меню, где необходимо будет о.

    Как включить макросы в Excel 2010, 2007, 2003

    После того как все получилось, перезагрузите приложение.

    Как включить макросы в Эксель

    • Для активации необходимо запустить программу, в верхней левой части нажать на «Файл».
    • Откроется окно, остановитесь на «Параметры».
    • В левой части запустившегося меню, отыщите «Безопасность».
    • Справа кликните по «Параметры центра управления».
    • Страница перегрузится, и справа, в верхнем столбце, нужно установить галочку рядом с «Включить все».

    Как включить макросы в Эксель

    • Обязательно подтвердите действия, выбрав в нижней части окна «Ок».

    Прежде чем приступить к активации, следует запомнить, что:

    • Макрорекордер запишет все действия пользователя, в том числе и ошибки.
    • Записываться будут только те действия, которые выполняются в Microsoft Excel. При переключении на другую программу запись остановится.
    • Макрорекордер способен записать действия, выполняемые серфером вручную.

    Чтобы Макрос работал корректно, не допуская оплошностей, обязательно продумайте действия перед началом записи.

    Excel 2010

    Для Excel 2010 года выпуска используется дополнительная вкладка на панели инструментов. Активировать ее можно следующим образом:

    1. Нажимаете Файл – Параметры.

    1. Переходите к настройкам ленты и в блоке основные вкладки ставите галочку напротив строки Разработчик. Подтверждаете действие нажатием кнопки ОК.

    Переходите к настройкам ленты

    1. Как видите, в основной ленте появилась новая вкладка. Щелкаете по ней и ищете кнопку Безопасность макросов. Программа автоматически открывает окно с настройкой защиты. Как и в предыдущем случае выбираете строку Включить все макросы.

    В основной ленте появилась новая вкладка

    Реализовать макрокоманды можно при помощи языка программирования Visual Basic (VBA), что требует определенных знаний от простого пользователя. Для упрощения процесса рекомендуем использовать запись последовательности действий в макрос. Для этого достаточно нажать кнопку Запись во вкладке Разработчик и производить действия на рабочем листе. Затем останавливаете запись и сохраняете макрокоманду. При этом редактор сам интерпретирует каждый шаг в отдельную программу.

    Реализовать макрокоманды

    Для версий 2013 и 2020 годов процесс активации макроса идентичен серии 2010 года. На windows 7 советуем использовать excel 2003 и 2007 года, а на windows 10 целесообразно пользоваться более свежими версиями.

    Важно! Рабочие книги excel, содержащие макросы, сохраняются в определенном формате, при открытии которого программа предлагает запустить макропрограмму. Давая свое согласие, Вы принимаете возможность содержания вируса в виде подпрограммы. В связи с этим будьте внимательны, при открытии неизвестных файлов, скачанных из сети или с какого-либо постороннего носителя.

    Теперь Вы знаете, как активировать макросы во всех сериях офисного редактора и даже если автоматически он отключился в результате сбоя или аварийного прекращения работы, то включить макропрограмму не составит труда.

    Абсолютная и относительная запись макроса

    Вы уже знаете про абсолютные и относительные ссылки в Excel? Если вы используете абсолютную ссылку для записи макроса, код VBA всегда будет ссылаться на те же ячейки, которые вы использовали. Например, если вы выберете ячейку A2 и введете текст «Excel», то каждый раз — независимо от того, где вы находитесь на листе и независимо от того, какая ячейка выбрана, ваш код будет вводить текст «Excel» в ячейку A2.

    Если вы используете параметр относительной ссылки для записи макроса, VBA не будет привязываться к конкретному адресу ячейки. В этом случае программа будет «двигаться» относительно активной ячейки. Например, предположим, что вы уже выбрали ячейку A1, и вы начинаете запись макроса в режиме относительной ссылки. Теперь вы выбираете ячейку A2, вводите текст Excel и нажмите клавишу Enter. Теперь, если вы запустите этот макрос, он не вернется в ячейку A2, вместо этого он будет перемещаться относительно активной ячейки. Например, если выбрана ячейка B3, она переместится на B4, запишет текст «Excel» и затем перейдет к ячейке K5.

    Теперь давайте запишем макрос в режиме относительных ссылок:

    1. Выберите ячейку A1.
    2. Перейдите на вкладку «Разработчик».
    3. В группе «Код» нажмите кнопку «Относительные ссылки». Он будет подсвечиваться, указывая, что он включен.
    4. Нажмите кнопку «Запись макроса».
    5. В диалоговом окне «Запись макроса» введите имя для своего макроса. Например, имя «ОтносительныеСсылки».

      Записать макрос в Excel - имя макроса

    6. В опции «Сохранить в» выберите «Эта книга».
    7. Нажмите «ОК».
    8. Выберите ячейку A2.
    9. Введите текст «Excel» (или другой как вам нравится).
    10. Нажмите клавишу Enter. Курсор переместиться в ячейку A3.
    11. Нажмите кнопку «Остановить запись» на вкладке «Разработчик».

    Макрос в режиме относительных ссылок будет сохранен.

    Теперь сделайте следующее.

    1. Выберите любую ячейку (кроме A1).
    2. Перейдите на вкладку «Разработчик».
    3. В группе «Код» нажмите кнопку «Макросы».
    4. В диалоговом окне «Макрос» кликните на сохраненный макрос «ОтносительныеСсылки».
    5. Нажмите кнопку «Выполнить».

    Как вы заметите, макрос записал текст «Excel» не в ячейки A2. Это произошло, потому что вы записали макрос в режиме относительной ссылки. Таким образом, курсор перемещается относительно активной ячейки. Например, если вы сделаете это, когда выбрана ячейка B3, она войдет в текст Excel — ячейка B4 и в конечном итоге выберет ячейку B5.

    Вот код, который записал макрорекодер:

    Код макроса VBA для относительной ссылки

    Обратите внимание, что в коде нет ссылок на ячейки B3 или B4. Макрос использует Activecell для ссылки на текущую ячейку и смещение относительно этой ячейки.

    Не обращайте внимание на часть кода Range(«A1»). Это один из тех случаев, когда макрорекодер добавляет ненужный код, который не имеет никакой цели и может быть удален. Без него код будет работать отлично.

    ( 2 оценки, среднее 4 из 5 )

    Макросы в Microsoft Excel

    Макросы – это инструмент для создания команд в приложении Microsoft Excel, которые позволяют значительно сократить время на выполнение задач, автоматизировав процесс. Но, в то же время, макросы являются источником уязвимости, которой могут воспользоваться злоумышленники. Поэтому, пользователь на свой страх и риск должен решить применять данную возможность в конкретном случае, или нет. Например, если он не уверен в благонадежности открываемого файла, то лучше макросами не пользоваться, ведь они могут послужить причиной заражения компьютера вредоносным кодом. Учитывая это, разработчики предоставили возможность пользователю самому решать вопрос включения и отключения макросов.

    Что такое макрос

    В Microsoft Office встроен специальный язык программирования, благодаря которому, человек может записывать определенные макрокоманды – макросы. При помощи таких программ, серферу не нужно выполнять одни и те же команды вручную.

    К примеру: ежедневно пользователю нужно удалять несколько ячеек в таблице, вместо которых вставляется текстовая часть документа. Чтобы не повторять подобные действия, можно записать их, используя макрорекордер. Выполнив всего несколько действий, можно экономить время в будущем, ведь после вызова инструмента, изменения будут проходить в автоматическом режиме.

    Стоит отметить, справиться с записью смогут даже новички, для выполнения работы ненужно обладать уникальными знаниями и навыками.

    Для одной из первых версий 2003 года процесс запуска макрокоманды следующий:

    1. На Панели управления ищете вкладку Сервис, затем из выпадающего списка выбираете строку Макрос и переходите в раздел Безопасность.

    1. Открывается новое диалоговое окно, в котором отображаются уровни безопасности. По умолчанию стоит либо высокая, либо очень высокая степень защиты. При такой настройке запустить подпрограмму практически невозможно. Поэтому ставите галочку напротив самого последнего пункта и нажимаете ОК.

    Открывается новое диалоговое окно

    На заметку! Чтобы изменения окончательно вступили в силу, необходимо закрыть и открыть редактор. Это общее правило для всех поколений Microsoft Office.

    Как включить макросы в Эксель

    • Для активации необходимо запустить программу, в верхней левой части нажать на «Файл».
    • Откроется окно, остановитесь на «Параметры».
    • В левой части запустившегося меню, отыщите «Безопасность».
    • Справа кликните по «Параметры центра управления».
    • Страница перегрузится, и справа, в верхнем столбце, нужно установить галочку рядом с «Включить все».

    Как включить макросы в Эксель

    • Обязательно подтвердите действия, выбрав в нижней части окна «Ок».

    Прежде чем приступить к активации, следует запомнить, что:

    • Макрорекордер запишет все действия пользователя, в том числе и ошибки.
    • Записываться будут только те действия, которые выполняются в Microsoft Excel. При переключении на другую программу запись остановится.
    • Макрорекордер способен записать действия, выполняемые серфером вручную.

    Чтобы Макрос работал корректно, не допуская оплошностей, обязательно продумайте действия перед началом записи.

    Ввод в код макроса функций и процедур

    Теперь усложним код макроса, задав ему два параметра:

    1. Название месяца отчета запрашиваем у пользователя.

    2. Последняя строка отчета БДР (в случае если она плавающая) рассчитывается в коде макроса.

    Функция InputBox

    Чтобы запросить у пользователя месяц отчета, воспользуемся функцией Inputbox, которая выводит диалоговое окно, в котором пользователь может самостоятельно задать значение переменной, используемой в коде. Синтаксис функции InputBox:

    Zapros = InputBox(«Текст запроса», <«Текст в шапке окна»>, <�Значение по умолчанию>,…)

    где Zapros — введенная вами переменная (имя придумываете вы сами), а в скобках через запятую перечисляются аргументы функции.

    Обратите внимание: первый аргумент является обязательным, то есть любое диалоговое окно должно сопровождаться пояснительным текстом, чего вы ждете от пользователя. Следующие аргументы обязательными не являются и их можно не указывать. То есть если вы хотите задать значение по умолчанию, но не хотите писать текст в шапке диалогового окна, разделите первый и третий аргументы двумя запятыми, как это будет сделано в нашем примере (см. далее).

    Для удобства присвойте полученное значение функции InputBox какой-нибудь введенной вами переменной, особенно если в коде макроса вы будете несколько раз использовать значение этой функции.

    Важно

    Имена вводимых переменных не должны совпадать с уже занятыми VBA словами под название объектов, свойств или функций!

    В нашем примере присвоим результат вызова функции InputBox переменной Mes.

    Например, нельзя завести свою переменную Range, Cells или Month — компилятор VBA предупредит вас, что делать этого нельзя, и не запустит макрос, пока вы не устраните ошибку (рис. 6).

    Рис. 6. Пример ошибки при заведении переменной

    Не забывайте любой текст в коде брать в кавычки! В противном случае компилятор VBA будет воспринимать этот текст как команды и выдавать ошибку, так как не сможет их обработать.

    Итак, приступим к редактированию кода макроса. Добавим в самое начало кода макроса строки:

    ‘ Запрашиваем у пользователя месяц отчета

    Mes = InputBox(«Введите название месяца отчета», , «Январь»)

    Теперь при запуске макроса будет выводиться диалоговое окно, в котором пользователь самостоятельно сможет указать, за какой месяц этот отчет (рис. 7).

    Рис. 7. Диалоговое окно для указания месяца

    С помощью функции InputBox можно запросить у пользователя и длину отчета. Но мы научим Excel высчитывать ее самостоятельно. Для этого нам потребуется процедура While.

    Процедура While

    Используется в коде, если надо сделать одинаковые действия несколько раз подряд до тех пор, пока выполняется какое-либо условие. Синтаксис процедуры While:

    Условие может состоять из одного выражения или содержать несколько, перечисленных через оператор AND (то есть оба условия должны быть выполнены) или OR (достаточно выполнения только одного из перечисленных условий). Также условие обязательно должно содержать переменную-счетчик (это может быть номер строки или столбца ячейки, значения которой вы проверяете).

    В список команд обязательно должна входить команда наращивания переменной-счетчика, иначе процедура зациклится (так как она постоянно будет сравнивать одно и то же значение) и макрос придется прерывать принудительно.

    Если макрос ушел в цикл, прервите его с помощью комбинации клавиш Ctrl+Break и либо прекратите макрос (кнопка End), либо зайдите в код макроса и исправьте ошибку (кнопка Debug). Чтобы макрос не уходил в цикл, рекомендуется включить в блок условий «защиту от дурака». Например, добавляем в условие проверку, чтобы значение счетчика не превышало определенной, заведомо достаточной для нас величины.

    Рассмотрим применение процедуры While для поиска конца отчета БДР.

    Как видно на рис. 4, последняя строка отчета имеет код «500». Напишем процедуру, которая будет проверять значения в ячейках столбца «А» и остановит свои действия, когда найдет ячейку с кодом «500».

    Обратите внимание!

    Excel иногда воспринимает числа как текст, поэтому включим два условия проверки значения ячейки и добавим «защиту от дурака» на случай, если в форме отчета случайно затрется код последней строки.

    Помним, что все текстовые значения надо брать в кавычки. Числа записываем без кавычек:

    ‘ Ищем последнюю строку отчета

    Dim Row_End As Integer ‘ Вводим переменную «счетчик номера строки»

    Row_End = 1 ‘ Присваиваем ей номер 1

    ‘ Начинаем процедуру поиска последней строки отчета по коду «500»

    Do While Cells(Row_End, 1).Value <> «500» And Cells(Row_End, 1).Value <> 500 And Row_End < 100

    ‘ До тех пор, пока код не равен 500 и номер строки меньше 100, выполняем наращивание счетчика

    Row_End = Row_End +1

    Loop

    Таким образом, процедура While нам нужна только для наращивания счетчика — никаких дополнительных действий она не производит. Запомните этот прием — он часто нужен в кодировании.

    Теперь заменим в изначальном коде макроса номер последней ячейки (34) на переменную Row_End. Число 34 было частью текста А1:С34, а теперь нам надо часть текста заменить на переменную. Делается это с помощью символа амперсанд &:

    «текст» & переменная & «текст».

    В нашем случае ссылка на диапазон А1:С34 будет записана так: А1:С & Row_End.

    Кроме того, вспоминаем, что и название отчета Бюджет на январь у нас тоже теперь содержит параметр и будет записываться так: Бюджет на & Mes.

    Не забывайте оставлять пробелы в кавычках перед переменной-словом, иначе текст сольется.

    Еще раз взглянем на получившийся код макроса:

    Sub Форматирование_БДР()

    ‘ Макрос выделяет жирным курсивом итоги, форматирует отчет на печать

    ‘ ——————

    ‘ Запрашиваем у пользователя месяц отчета

    Mes = InputBox(«Введите название месяца отчета», , «Январь»)

    ‘ Ищем последнюю строку отчета

    Dim Row_End As Integer ‘ Вводим переменную «счетчик номера строки»

    Row_End = 1 ‘ Присваиваем ей номер 1

    ‘ Начинаем процедуру поиска последней строки отчета по коду «500»

    ‘ Критичным значением для «защиты от дурака» принимаем номер строки 100

    Do While Cells(Row_End, 1).Value <> «500» And Cells(Row_End, 1).Value <> 500 And Row_End < 100

    ‘ До тех пор, пока код не равен 500 и номер строки меньше 100, выполняем наращивание счетчика

    Row_End = Row_End +1

    Loop

    ‘ Выделяем столбцы и ставим фильтр на КОД

    Columns(«A:C»).Select

    Selection.AutoFilter

    ActiveSheet.Range(«$A$1:$C$» & Row_End).AutoFilter Field:=1, Criteria1:=»<>*.*», _

    Operator:=xlAnd

    ‘ Выделяем отфильтрованный диапазон полужирным шрифтом, снимаем фильтр

    Range(«A1:C» & Row_End).Select

    Selection.Font.Bold = True

    Selection.AutoFilter

    ‘ Форматируем на печать: верхний колонтитул, центрирование по горизонтали, масштаб 75 %

    With ActiveSheet.PageSetup

    .CenterHeader = «Бюджет на » & Mes

    .CenterHorizontally = True

    .Zoom = 75

    End With

    End Sub

    Теперь макрос стал более универсальным. Добавим в него еще одну «защиту от дурака».

    Если нам принципиально, правильно ли макрос нашел последнюю строку отчета, после окончания процедуры While (строка Loop) можно добавить блок проверки значения Row_End и запроса у пользователя подтверждения на продолжение макроса.

    Для этого изучим функцию MsgBox, процедуру IF и команду Exit Sub.

    Функция MsgBox

    MsgBox — еще один способ общения с пользователем: сообщения ему какой-то информации по ходу выполнения макроса или запрос у него подтверждения по дальнейшим действиям макроса путем нажатия на кнопки вида Yes, No, Ок, Cancel.

    Она имеет два вида записи:

    1. Мы просто сообщаем пользователю какую-то информацию. В этом случае аргументы функции перечисляются сразу же за функцией, без использования скобок:

    MsgBox «Текст сообщения», <�Вид кнопок>, <«Текст в шапке окна»>,…

    На экране отобразится диалоговое окно, и после нажатия пользователем кнопки Ок продолжится выполнение макроса (рис. 8).

    Рис. 8. Первый вид записи функции MsgBox

    Как и в случае с функцией InputBox, обязательным здесь является только первый аргумент — Текст сообщения. Остальные можно даже не указывать, сократив вид записи функции до вида:

    2. Нам важно, что ответил пользователь, мы записываем его ответ в значение какой-то переменной (рис. 9). В этом случае аргументы функции заключаются в скобки, а перед функцией обязательно должна стоять переменная, в которую мы записываем, на какую кнопку нажал пользователь:

    YesNo = MsgBox(«Текст сообщения», <�Вид кнопок>, <«Текст в шапке окна»>,…)

    Рис. 9. Второй вид записи функции MsgBox

    Варианты вида кнопок:

    • vbOKOnly — только кнопка ОК;
    • vbOKCanсel — кнопки ОК и Cancel;
    • vbYesNo — кнопки Yes и No;
    • vbYesNoCancel — кнопки Yes, No и Cancel.

    Соответственно в зависимости от нажатой кнопки значения функции MsgBox могут быть vbOK, vbCancel, vbYes или vbNo.

    Процедура If

    С помощью данной процедуры можно разбить команды кода на две ветки в зависимости от выполнения заданного условия. Синтаксис процедуры If:

    If <�условие, которое должно быть верным> Then

    <�список команд при выполнении указанного условия>

    else

    <�список команд при невыполнении указанного условия>

    End If

    Обязательным к заполнению является только условие. Список команд в обоих блоках заполнять не обязательно. В зависимости от ваших задач вы можете заполнить оба блока или только один из них. Условие может состоять из одного выражения или содержать несколько выражений, перечисленных через оператор AND (то есть оба условия должны быть выполнены) или оператор OR (достаточно выполнения только одного из перечисленных условий).

    Команда Exit Sub

    Прекращает выполнение макроса. Обычно ее используют в ветках процедуры If при проверке допустимости дальнейшего исполнения макроса. Обратите внимание: ни одно действие после команды Exit Sub выполнено не будет. Поэтому если вы хотите сообщить пользователю о принудительном прекращении процедуры, команду MsgBox нужно расположить выше команды Exit Sub.

    Итак, объединим новые знания в код «защиты от дурака» и запишем его после строки Loop:

    ‘ Проверяем, дошла ли процедура While до «критичной» строки 100

    ‘ и спрашиваем подтверждение о продолжении выполнения макроса

    If Row_End = 100 Then

    YesNo = MsgBox(«Поиск последней строки отчета дошел до 100, продолжаем?», vbYesNo)

    If YesNo = vbNo Then ‘ Если нажата кнопка «No», то…

    MsgBox «Процедура прервана пользователем» ‘ 1. выдаем сообщение для пользователя,

    Exit Sub ‘ 2. останавливаем макрос

    End If

    End If

    В нашем коде прошло вложение одной процедуры If в другую:

    • сначала мы проверили, дошел ли счетчик Row_End до значения 100;
    • если дошел, мы спрашиваем у пользователя, продолжать ли нам выполнение макроса;
    • если пользователь ответил «нет», останавливаем макрос.

    В обеих процедурах If мы опустили второй блок (else): если Row_End не достиг значения 100 или пользователь ответил «да», макрос просто покинет процедуру If и продолжит выполнять команды, написанные ниже.

    Каждая процедура If должна заканчиваться командой End If. Если количество строк с командой If не будет соответствовать количеству строк с командой End If, компилятор VBA сообщит об ошибке и вам придется искать, где вы потеряли конец процедуры If.

    Поэтому рекомендуется сразу писать обе строки, а потом уже наполнять процедуру командами.

    Также для удобства визуального восприятия кода макроса рекомендуется каждую вложенную процедуру начинать с отступа, чтобы визуально было понятно, где заканчивается вложенная процедура и продолжается список команд процедуры верхнего уровня.

    Как сохранить

    Если желаете записать команды, необходимо следовать нижеописанной инструкции. В первую очередь обратите внимание на верхнюю панель в Эксель, здесь должна располагаться вкладка «Разработчик». Если ее нет, выполните следующие действия:

    • Слева нажмите на «Файл», кликните по «Параметры».
    • В левой части остановитесь на «Настройки ленты».
    • Справа установите галочку рядом с «Разработчик».
    • С этого момента появится нужный инструмент, кликнув по которому нужно остановиться на «Запись».

    На следующем этапе придумайте название, дайте краткое описание и определитесь, куда сохраниться макрос. Нажмите на «Ок», чтобы подтвердить действия.

    Как включить макросы в Эксель

    • Обязательно давайте понятное название и описание, чтобы в дальнейшем не путаться в списке многочисленных команд.
    • Для прекращения записи, кликните по «Остановить».
    • Чтобы запустить записанную ранее команду, в разделе разработчика, слева, остановитесь на искомом элементе.
    • После нажатия откроется окно, где будут показаны все команды, которые серфер записывал на протяжении всего времени. Кликните по нужному, чтобы он выделился синим цветом, остановитесь на «Выполнить.

    Как включить макросы в Эксель

    Зная как включить макросы в Эксель можно сэкономить время, ведь благодаря автоматическому выполнению команд, пользователю не придется вручную проделывать одинаковую работу ежедневно.

    Правила написания команд в VBA

    Любая команда макроса состоит из двух блоков, разделенных точкой:

    Объект.Действие с объектом или свойство объекта

    Объектами в Excel являются, например:

    • книга: WorkBook, ActiveWorkbook;
    • лист, листы: WorkSheet, ActiveSheet, Sheets;
    • ячейка: Cells(1,1) — в скобках указываются номера строки (Row) и столбца (Column) ячейки на листе;
    • диапазон ячеек (может быть и одна ячейка): Range(«А1:С5»), Range(«А1»);
    • строки (Rows);
    • столбцы (Columns);
    • выделение (Selection) — выделенный в данный момент диапазон (это может быть как несколько смежных ячеек, так и смежные строки или столбцы).

    Примеры действий с объектами:

    • ActiveWorkbook.Save — сохранить рабочую книгу (та, которая была активна в момент вызова пользователем макроса);
    • Sheets(«Лист3»).Name = «Отчет» — переименовать «Лист3» в «Отчет»;
    • Sheets(«Отчет»).Activate — перейти на лист с названием «Отчет»;
    • Range(«А1»).Copy — скопировать в буфер обмена данные из ячейки А1;
    • Rows(«13:13»).Delete Shift:=xlUp — удалить строку 13 со сдвигом вверх.

    Примеры свойств объектов:

    • ActiveCell.FormulaR1C1 = «БДР» — в выделенной (активной) ячейке записан текст «БДР»;
    • ActiveCell.Row < 65 — номер ряда активной ячейки меньше 65.

    Помнить все названия объектов, команд и свойств для написания несложных макросов не обязательно. Вы всегда можете сначала записать ваши стандартные действия с отчетами в Excel, а потом отформатировать код макроса, убрав из него лишние действия или заменив некоторые заданные параметры (например, длину диапазона) на переменные (которые в дальнейшем макрос будет запрашивать у пользователя или рассчитывать самостоятельно).

    Но об этом мы расскажем далее, а сейчас обратимся к коду нашего первого макроса, состоящего из одной строки:

    Selection.NumberFormat = «#,##0»

    Суть его в следующем: к объекту Выделенный диапазон (у нас одна ячейка, но это может быть и весь столбец/строка или диапазон смежных ячеек) применяется свойство Числовой формат вида # ##0 (если помните, именно этот формат мы выбрали в списке).

    Код макроса Форматирование_БДР и расшифровка строк кода представлены в таблице.

    Строка кода Расшифровка
    Sub Форматирование_БДР() Начало макроса, имя макроса
    Пустая строка комментариев (ставится автоматически при записи макроса)
    ‘ Форматирование_БДР Макрос Автоматически добавленный комментарий при записи макроса — может быть удален без потери работоспособности макроса
    ‘ Выделяем жирным курсивом итоги, форматируем на печать Автоматически добавленный комментарий при записи макроса из поля Описание
    Пустая строка — не влияет на суть исполнения макроса, но их полезно добавлять для разделения блоков команд внутри кода
    Columns(«A:C»).Select Выделить (Select) объект Столбцы (Columns) А:С
    Selection.AutoFilter Применить автофильтр (AutoFilter) для выделенного диапазона (Selection)
    ActiveSheet.Range(«$A$1:$C$34″).AutoFilter Field:=1, Criteria1:=»<>*.*», _ Задать критерий отбора «не содержит точку»
    Operator:=xlAnd Продолжение команды из предыдущей строки.

    Обратите внимание: предыдущая строка закончилась символом нижнего подчеркивания _, значит, текст команды не уместился на одну строку и окончание команды перенесено на следующую

    Range(«A1:C34»).Select Выделить (Select) объект Диапазон (Range) А1:С34.

    Обратите внимание: какой бы длины ни был ваш следующий отчет, для которого вы будете применять этот макрос, выделится всегда только диапазон до 34 строки!

    Как сделать этот диапазон любой длины — обсудим немного позже

    Selection.Font.Bold = True Для выделенного диапазона (Объект Selection) установить свойство «полужирный шрифт» (Font.Bold = True). Если нужно отменить какое-то свойство, пишем False
    Selection.AutoFilter Снять автофильтр (при записи макроса это было повторное нажатие кнопки Фильтр на закладке Данные)
    With ActiveSheet.PageSetup Начало процедуры With (используется, если далее перечисляются свойства или действия с одним и тем же объектом для компактности записи кода).

    Для объекта ActiveSheet (Текущий лист) применить следующие параметры свойства PageSetup (Параметры печати):

    .PrintTitleRows = «» Печатать на каждой странице сквозные строки — пусто (то есть данное свойство не задано пользователем)
    .PrintTitleColumns = «» Печатать на каждой странице сквозные столбцы — пусто
    End With Окончание процедуры With
    ActiveSheet.PageSetup.PrintArea = «» Заданная область печати — пусто (то есть пользователь не ограничил область печати, следовательно, на экран будет выведено все, что есть на листе)
    With ActiveSheet.PageSetup Начало процедуры With

    Для объекта Текущий лист применить следующие параметры печати (цветом выделены те, которые мы изменили по сравнению со стандартными):

    .LeftHeader = «» Левый верхний колонтитул — пусто
    .CenterHeader = «Бюджет на январь» Центральный верхний колонтитул — задан текст пользователем
    .RightHeader = «» Правый верхний колонтитул — пусто
    .LeftFooter = «» Левый нижний колонтитул — пусто
    .CenterFooter = «» Центральный нижний колонтитул — пусто
    .RightFooter = «» Правый нижний колонтитул — пусто
    .LeftMargin = Application.InchesToPoints(0.708661417322835) Размеры левого поля
    .RightMargin = Application.InchesToPoints(0.708661417322835) Размеры правого поля
    .TopMargin = Application.InchesToPoints(0.748031496062992) Размеры верхнего поля
    .BottomMargin = Application.InchesToPoints(0.748031496062992) Размеры нижнего поля
    .HeaderMargin = Application.InchesToPoints(0.31496062992126) Размеры верхнего колонтитула
    .FooterMargin = Application.InchesToPoints(0.31496062992126) Размеры нижнего колонтитула
    .PrintHeadings = False Не печатать заголовки строк и столбцов (False — пользователь не отметил этот пункт)
    .PrintGridlines = False Не печатать сетку
    .PrintComments = xlPrintNoComments Не печатать примечания
    .PrintQuality = 600 Качество печати — 600 точек на дюйм
    .CenterHorizontally = True Центрировать на странице горизонтально (True — пользователь отметил этот пункт)
    .CenterVertically = False Не центрировать по вертикали
    .Orientation = xlPortrait Ориентация страницы — книжная
    .Draft = False Пользователь не отметил пункт Черновая в блоке Печать
    .PaperSize = xlPaperA4 Размер бумаги А4
    .FirstPageNumber = xlAutomatic Номер первой страницы — автоматически
    .Order = xlDownThenOver Последовательность вывода страниц: вниз, потом вправо (пункт в блоке Печать)
    .BlackAndWhite = False Пользователь не отметил пункт Черно-белая в блоке Печать
    .Zoom = 75 Масштаб 75 %
    .PrintErrors = xlPrintErrorsDisplayed Пункт в блоке ПечатьОшибки ячеекКак на экране
    .OddAndEvenPagesHeaderFooter = False Пользователь не задавал разные колонтитулы для четных и нечетных страниц (флажок в блоке Колонтитулы)
    .DifferentFirstPageHeaderFooter = False Пользователь не задавал отдельный колонтитул для первой страницы (флажок в блоке Колонтитулы)
    .ScaleWithDocHeaderFooter = True Флажок в блоке Колонтитулы – Изменять вместе с масштабом страницы отмечен пользователем
    .AlignMarginsHeaderFooter = True Флажок в блоке Колонтитулы – Выровнять относительно полей страницы отмечен пользователем
    .EvenPage.LeftHeader.Text = «» Текст колонтитулов для четных и первой страниц не задан
    .EvenPage.CenterHeader.Text = «»
    .EvenPage.RightHeader.Text = «»
    .EvenPage.LeftFooter.Text = «»
    .EvenPage.CenterFooter.Text = «»
    .EvenPage.RightFooter.Text = «»
    .FirstPage.LeftHeader.Text = «»
    .FirstPage.CenterHeader.Text = «»
    .FirstPage.RightHeader.Text = «»
    .FirstPage.LeftFooter.Text = «»
    .FirstPage.CenterFooter.Text = «»
    .FirstPage.RightFooter.Text = «»
    End With Окончание процедуры With
    End Sub Окончание кода макроса

    Подведем итоги

    Мы с вами научились:

    • записывать макросы через команду Вид Макросы Запись макроса;
    • редактировать автоматически записанный макрос, удалять из него лишние команды;
    • унифицировать код макроса, вводя в него переменные, которые макрос запрашивает у пользователя или рассчитывает самостоятельно,

    а также изучили функции InputBox и MsgBox, процедуры While и If, команду Exit Sub.

    В следующем номере рассмотрим процедуру FOR, запишем макрос суммирования результирующих статей БДР, научимся тестировать макросы и выносить кнопки вызова макроса на панель быстрого доступа.

    Расширение файлов Excel, которые содержат макросы

    Когда вы записываете макрос или вручную записываете код VBA в Excel, вам необходимо сохранить файл с расширением файла с поддержкой макросов (.xlsm).

    До Excel 2007 был достаточен один формат файла — .xls. Но с 2007 года .xlsx был представлен как стандартное расширение файла. Файлы, сохраненные как .xlsx, не могут содержать в себе макрос. Поэтому, если у вас есть файл с расширением .xlsx, и вы записываете / записываете макрос и сохраняете его, он будет предупреждать вас о сохранении его в формате с поддержкой макросов и покажет вам следующее диалоговое окно:

    Сохранение файла с поддержкой макросов

    Если вы выберете «Нет», Excel сохранить файл в формате с поддержкой макросов. Но если вы нажмете «Да», Excel автоматически удалит весь код из вашей книги и сохранит файл как книгу в формате .xlsx. Поэтому, если в вашей книге есть макрос, вам нужно сохранить его в формате .xlsm, чтобы сохранить этот макрос.

    Что нельзя сделать с помощью макрорекодера?

    Макро-рекордер отлично подходит для вас в Excel и записывает ваши точные шаги, но может вам не подойти, когда вам нужно сделать что-то большее.

    • Вы не можете выполнить код без выбора объекта. Например, если вы хотите, чтобы макрос перешел на следующий рабочий лист и выделил все заполненные ячейки в столбце A, не выходя из текущей рабочей таблицы, макрорекодер не сможет этого сделать. В таких случаях вам нужно вручную редактировать код.
    • Вы не можете создать пользовательскую функцию с помощью макрорекордера. С помощью VBA вы можете создавать пользовательские функции, которые можно использовать на рабочем листе в качестве обычных функций.
    • Вы не можете создавать циклы с помощью макрорекордера. Но можете записать одно действие, а цикл добавить вручную в редакторе кода.
    • Вы не можете анализировать условия: вы можете проверить условия в коде с помощью макрорекордера. Если вы пишете код VBA вручную, вы можете использовать операторы IF Then Else для анализа условия и запуска кода, если true (или другой код, если false).

    #Руководства

    • 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» и выбираем пункт «Параметры…».

    Нажимаем сюда, чтобы вызвать панель с дополнительными параметрами Excel в macOS
    Скриншот: 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
    Узнать больше

    Хитрости »

    1 Май 2011              465201 просмотров


    Что такое макрос и где его искать?

    Скачать файл, используемый в видеоуроке:

      Tips_Macro_Basic_Video.xls (63,5 KiB, 4 006 скачиваний)


    Наверное, многие слышали это слово «макрос«, но не все имеют точное представление что это, если заглянули на эту страничку.

    Макрос

    — это макрокоманда(так звучит в правильном переводе с англ.языка), содержащая последовательность действий, записанных пользователем. Запись производится с помощью встроенного в пакет Microsoft Office языка программирования — Visual Basic for Application(VBA).

    Зачем же нужны макросы? А нужны они для того, чтобы избавить Вас от рутинного выполнения одних и тех же действий. Например, Вам каждый день приходиться удалять из ежедневных отчетов по несколько столбцов и добавлять новые строки для шапки и т.п. Скучно и утомительно. Вы просто можете записать один раз все эти действия макрорекордером, а в дальнейшем только вызывать записанный макрос и он все сделает за Вас. Что немаловажно, для использования макрорекордера и записи макроса не надо обладать никакими навыками программирования.
    В этой статье:

    • Подготовка к записи макроса
    • Запись макроса
    • Параметры записи макроса
    • Воспроизведение макроса
    • В каких файлах можно хранить макросы?
    ПОДГОТОВКА К ЗАПИСИ МАКРОСА

    Прежде чем начать работать с макросами необходимо разрешить их выполнение, т.к. по умолчанию они отключены. Для этого необходимо сделать следующее:

    • Excel 2003:
      Сервис-Безопасность-Уровень макросов «Низкий»
    • Excel 2007:
      Кнопка ОфисПараметры Excel (Excel Options)Центр управления безопасностью (Trust Centr)Параметры центра управления безопасностью (Trust Centr Settings)Параметры макросов (Macro Settings)Разрешить все макросы (Enable All Macros)
    • Excel 2010:
      Файл (File)Параметры (Options)Центр управления безопасностью (Trust Centr)Параметры центра управления безопасностью (Trust Centr Settings)Параметры макросов (Macro Settings)Разрешить все макросы (Enable All Macros)
    • После изменения параметров безопасности макросов необходимо перезапустить приложение Excel: закрыть его полностью и открыть заново. Только после этого изменения вступят в силу.

    Прежде чем начать записывать макрос необходимо помнить следующее:

    • Макрорекордер записывает АБСОЛЮТНО ВСЕ ваши действия – ошибки, прокручивание экрана, переключение между листами, выделение ячеек и т.д. Поэтому перед записью своих действий необходимо сначала тщательно продумать все свои действия, чтобы в дальнейшем записать только то, что действительно необходимо записать и в дальнейшем воспроизвести. Это сократит как сам код, так и время его выполнения
    • Макрорекордер записывает действия выполненные только в пределах Microsoft Excel. Если вы переключитесь в другое приложение – действия в этой программе записаны не будут. Если закроете Excel – запись прекратится
    • Макрорекордер может записать только те действия, которые можно проделать вручную(те, которые доступны для выполнения из меню и с панелей)
    • Если во время кода вы совершили ошибочное действие и нажали кнопку отмены(Ctrl+Z) – отмененное действие не будет записано в макрос, как будто вы его просто не делали
    ЗАПИСЬ МАКРОСА

    Для пользователей Excel 2003 запись макроса возможна через меню:
    СервисМакрос Начать Запись
    Начать запись

    Для пользователей Excel 2007-2010 и старше:

    ПАРАМЕТРЫ ЗАПИСИ МАКРОСА

    Перед записью можно задать имя записываемому макросу и назначить сочетание клавиш, при нажатии которых этот макрос будет запускаться. После нажатия кнопки для начала записи макроса появится окно:
    Диспетчер записи макроса

    Имя макроса

    – не должно содержать пробелов, запятых, двоеточий и т.п. Допустимы символы кириллицы, латиницы, цифры и нижнее подчеркивание (я рекомендую давать макросам имена, содержащие только буквы латиницы). Имя макроса всегда должно начинаться с буквы и не должно совпадать со встроенным именем Excel или именем другого объекта в книге (например, не должно носить имя Workbook, Cells или ЭтаКнига). Лучше давать макросу сразу понятное имя, отражающее примерную суть того, что он делает.

    Сочетание клавиш

    – можно назначить вызов макроса сочетанием клавиш. Доступно назначение любой цифры или буквы в сочетании с Ctrl.

    Сохранить в

    – выбираете место хранения записываемого макроса. Доступны варианты:

    • Эта книга (This Workbook) – макрос будет записан в той же книге, из которой была запущена запись. Записанный макрос будет доступен из приложения только если книга открыта
    • Новая книга (New Workbook) – будет создана новая книга, в которой записан макроса. Записанный макрос будет доступен из приложения только если книга открыта
    • Личная книга макросов (Personal Macro Workbook) – самый интересный вариант. Если его выбрать, то макрос будет сохранен в отдельной книге PERSONAL.XLS (для Excel 2007 и выше — PERSONAL.XLSB). Макросы, записанные в эту книгу доступны из всех открытых книг Excel и эта книга подключается автоматически при запуске самого Excel. Т.е. однажды записав где-то макрос в эту книгу – он теперь будет доступен из любой книги независимо от того, открыта ли книга, из которой был записан макрос или нет. Изначально эта книга отсутствует и создается в момент первого обращения к ней (т.е. как только вы первый раз выбрали Сохранить в личную книгу макросов)
    ВОСПРОИЗВЕДЕНИЕ МАКРОСА

    После записи макроса запустить его можно разными способами:

    1. ПРИ ПОМОЩИ СОЧЕТАНИЯ КЛАВИШ: Alt+F8
      Этот способ универсальный и его можно использовать из любой версии Excel. Достаточно нажать сочетание клавиш Alt+F8 и выбрать нужный макрос из списка:
      Вызов макроса
    2. ВЫЗОВ ИЗ МЕНЮ:
      Excel 2007-2010 и старше: вкладка Разработчик (Developer)Макросы (Macros)
      Excel 2003: СервисМакросМакросы
    3. НАЖАТИЕМ СОБСТВЕННОЙ КНОПКИ НА ЛИСТЕ:
      Можно разместить на листе собственную кнопку, по нажатии которой будет запускаться записанный макрос. Подробно этот процесс я описал в статье: Как создать кнопку для вызова макроса на листе
    4. ПРИ ПОМОЩИ НАЗНАЧЕННЫХ МАКРОСУ ГОРЯЧИХ КЛАВИШ:
      Если вы перед записью назначили макросу сочетание клавиш, то вы также можете вызвать этот макрос и нажатием данного сочетания. Горячие клавиши макросу можно назначить и после записи: Alt+F8→ Выделяем нужный макрос→ Параметры (Options).
    5. ПРИ НАСТУПЛЕНИИ ОПРЕДЕЛЕННОГО СОБЫТИЯ В ЛИСТЕ ИЛИ КНИГЕ:

      Прежде чем пробовать использовать этот метод рекомендуется изучить статью Что такое модуль? Какие бывают модули?Для этого сначала необходимо вставить код макроса в тело событийной процедуры (подробнее про событийные процедуры). Например, если выбрать процедуру листа Change, то в лист автоматически будет вставлена пустая процедура:

      Private Sub Worksheet_Change(ByVal Target As Range)
       
      End Sub

      Если ранее вами был записан код выделения и удаления двух столбцов – Макрос1:

      Sub Макрос1()
      '
      ' Макрос1 Макрос
      ' макрос удаляет столбцы C и D из активного листа
      '
      ' Сочетание клавиш: Ctrl+Shift+Q
      '
          Columns("C:D").Select
          Selection.Delete Shift:=xlToLeft
      End Sub

      То для выполнения это кода при наступлении события изменения на листе можно вставить вызов этого макроса:

      Private Sub Worksheet_Change(ByVal Target As Range)
          Call Макрос1
      End Sub

      или вставить сам код (без Sub и End Sub) внутрь процедуры Worksheet_Change:

      Private Sub Worksheet_Change(ByVal Target As Range)
          Columns("C:D").Select
          Selection.Delete Shift:=xlToLeft
      End Sub
    В каких файлах можно хранить макросы?

    Как ни странно, но начиная с версии 2007 Excel не все файлы могут хранить макросы. Это значит, что если макрос был записан в файле и потом файл был сохранен в формате, который хранение макросов не поддерживает — макросы пропадут. Как правило Excel в таком случае выдаст предупреждение о том, что проект VBA в файле этого формата не может быть сохранен и будет удален, если нажать Да:
    Сохранение без макросов
    Чтобы сохранить файл с поддержкой макросов необходимо будет нажать Нет и из списка форматов выбрать тот, который поддерживает хранение макросов.
    Ниже приведены форматы файлов, применяемые в Excel с описанием того, можно ли в них хранить макросы(VBA коды):

    • *.xls – формат книги Excel 97–2003 (поддержка VBA, макросов)
    • *.xla – надстройка Excel 97–2003 (поддержка VBA, макросов)
    • *.xlsx – формат книги Excel 2007 по умолчанию без поддержки макросов
    • *.xlsm – книга Excel 2007 с поддержкой макросов
    • *.xlsb – двоичный формат для больших объемов данных (с поддержкой VBA, макросов)
    • *.xltx – шаблон книги Excel 2007 без поддержки макросов
    • *.xltm – шаблон книги Excel 2007 с поддержкой макросов
    • *.xlam – надстройка Excel 2007

    Для смены формата файла его необходимо сохранить в другом формате:

    • Excel 2007: Кнопка ОфисСохранить как(SaveAs) -Выбрать необходимый формат файла
    • Excel 2010: Файл(File)Сохранить как(SaveAs) -Выбрать необходимый формат файла

    Теперь несложно понять, что хранить макросы в версиях Excel 2007 и выше можно в форматах: xls, xla, xlsm, xlsb, xltm, xlsm.

    Также см.:
    Почему не работает макрос?
    Как создать кнопку для вызова макроса на листе?
    Select и Activate — зачем нужны и нужны ли?
    Как ускорить и оптимизировать код VBA


    Статья помогла? Поделись ссылкой с друзьями!

      Плейлист   Видеоуроки


    Поиск по меткам

    

    Access
    apple watch
    Multex
    Power Query и Power BI
    VBA управление кодами
    Бесплатные надстройки
    Дата и время
    Записки
    ИП
    Надстройки
    Печать
    Политика Конфиденциальности
    Почта
    Программы
    Работа с приложениями
    Разработка приложений
    Росстат
    Тренинги и вебинары
    Финансовые
    Форматирование
    Функции Excel
    акции MulTEx
    ссылки
    статистика


    Программа Excel по умолчанию настроена таким образом, что макросы не будут запускаться. В связи с этим у многих начинающих пользователей может появиться потребность включить или отключить макросы.

    Сегодня мы и рассмотрим с вами как это можно сделать в различных версиях Excel. Вам потребуется сделать это только один раз. После этого настройки будут сохранены и макросы будут запускаться автоматически.

    Содержание

        • 0.0.1 Как включить или отключить макросы в Excel 2003
    • 1 Как включить или отключить макросы в Excel 2007
    • 2 Как включить или отключить макросы в Excel 2010

    Как включить или отключить макросы в Excel 2003

    Чтобы включить или отключить макросы в Excel 2003 вам необходимо зайти в следующее меню Сервис | Макрос | Безопасность

    Как включить или отключить макросы

    В открывшемся окне переставьте переключатель Уровень безопасности в положение Средняя или Низкая.

    Как разрешить запускать макросы в Excel

    Очень важно после этого закрыть и снова открыть данный файл, без этого вы не увидите разницы в текущем файле. Как мы уже писали это необходимо сделать один раз и после этого настройки будут сохранены и макросы в Excel 2003 будут запускаться автоматически

    Как включить или отключить макросы в Excel 2007

    В Excel 2007 включить или отключить макросы можно таким же способом, но данное меню находится в другом месте. В Excel 2007 это можно сделать в окне Параметры макросов. Чтобы попасть в данное меню вам необходимо перейти в Меню | Параметры Excel

    Как включить или отключить макросы в Excel 2010

    В открывшемся окне необходимо запустить Центр управления безопасностью | Параметры центра управления безопасностью | Параметры макросов

    kak-otklyuchit-vklyuchit-makrosy-excel2007-2

    В окне параметров макроса выберете пункт Включить все макросы (не рекомендуется, возможен запуск опасной программы).

    После этого вам также необходимо закрыть и открыть файл Excel, чтобы изменения вступили в силу. В дальнейшем макросы будут запускаться в Excel 2007 автоматически.

    Более быстрый способ мы рассмотрим на примере Excel 2010, но он полностью подходит и для Excel 2007

    Как включить или отключить макросы в Excel 2010

    Запуск макросов в Excel 2010 аналогичен Excel 2007 в связи с этим мы рассмотрим другой способ открыть окно Параметры макросов для возможности включать или отключать макросы.

    Для этого необходимо перейти в раздел Разработчик | Безопасность макросов | Параметры макросов | Включить все макросы (не рекомендуется, возможен запуск опасной программы)

    Как включить макросы в Excel 2010

    Стоит отметить, что раздел панели инструментов Разработчик в Excel 2007 доступен по умолчанию, а в Excel 2010 его необходимо включить. Это особенно полезно сделать тем пользователям, которые будут часто работать с макросами. Чтобы включить панель инструментов Разработчик в Excel 2010 необходимо запустить Файл | Параметры | Настройка ленты после этого необходимо с правой стороны необходимо поставить галочку напротив надписи Разработчик

    Как включить панель разработчик в Excel

    Очень надеемся, что наша статья помогла вам в решении вашей проблемы. Будем благодарны, если вы нажмете +1 и/или Мне нравится внизу данной статьи или поделитесь с друзьями с помощью кнопок расположенных ниже.

    Спасибо за внимание.

    Макрос – это одна из важнейших составляющих офисного приложения Excel, позволяющая без знания языка программирования создавать специальные команды, запуская которые удаётся быстро выполнять операции, предусмотренные производственными задачами.

    Активация макросов Excel

    Макрокоманды позволяют выполнять некоторые действия на полном автомате

    Макросы значительно сокращают время, необходимое на выполнение однотипных заданий. Именно это объясняет такую высокую заинтересованность в их использовании со стороны большинства пользователей. Однако при первом запуске Excel, запустить макрос не удастся, поскольку по умолчанию функция воспроизведения макрокоманд отключена.

    Желая повысить эффективность своей работы, многие стараются изучить информацию, как писать макросы в Excel, однако специалисты настоятельно рекомендуют первоначально разобраться, как включить макросы в Excel.

    Отображение в Office 2003

    В Excel макрокоманды включаются несложно, но первоначально следует пользователю выяснить, какой офис у него инсталлирован на компьютере, поскольку порядок действий, как запустить макрос в Excel в разных офисах немного отличается.

    Office 2003

    Чтобы включить макросы в Excel 2003, первоначально потребуется открыть непосредственно сам табличный редактор. Далее на самой верхней панели, среди предложенных инструментов меню, необходимо найти «Сервис», кликнув по которому, откроется контекстное меню, в перечне которого нужно найти пункт «Макрос».

    Наведя курсор мышки на эту строку, открывается новое контекстное меню, среди которого выбор следует сделать на строке «Безопасность». Кликнув по нему, на экране отобразится диалоговое окно, предлагающее пользователю выбрать уровень безопасности. По умолчанию чаще всего переключатель установлен на высоком или очень высоком уровне безопасности, при котором макрокоманды просто так не запускаются.

    Настройка редактора Excel

    Переставив переключатель в позицию среднего или низкого уровня безопасности, пользователю удастся впоследствии писать, запускать и редактировать макрокоманды.

    Чтобы все произведённые изменения вступили в силу, необходимо перезапустить Excel, просто закрыв и сразу же его открыв.

    Выбор уровня безопасности

    Ознакомившись с информацией, как создать макрос в Excel, пользователь сможет практически сразу приступить к созданию команд, в которых так часто нуждается. Автоматическое выполнение функциональных команд сэкономит рабочее время и не спровоцирует усталость вследствие выполнения однообразной работы.

    Отображение в Microsoft Office 2007 и 2010

    Включить макрокоманды можно и в табличном редакторе нового поколения, только придётся воспользоваться несколько иными инструкциями, потому что панель инструментов, расположение меню офисов различных лет выпуска отличаются между собой.

    Office 2007

    По сути, включить макрокоманды в табличном редакторе офиса 2007 можно таким же самым способом, как и в Excel 2003. Отличие заключается лишь в том, что для открытия диалогового окна «Параметры макросов» приходится проделать несколько иной путь.

    В офисе 2007 первоначально необходимо зайти в Меню, расположенное в верхнем левом углу, после чего сразу же осуществить переход в «Параметры Excel».

    Расположение меню настроек в Excel 2007

    Вслед за этим на экране компьютера появится диалоговое окно «Центр управления безопасностью», визуально изучив которое можно без труда обнаружить строку «Параметры центра управления безопасностью», по которой нужно сразу же кликнуть левой клавишей мышки.

    После осуществления последовательных переходов на экране отобразится подменю «Параметры макросов», предоставляющее возможность вносить изменения в процесс отображения, написания и запуска различных макрокоманд.

    В новом открывшемся окне переключатель нужно установить на последней строке «Включить все макросы». Система, конечно, предупредит, что такие действия могут позволить осуществлять запуск и опасных программ. Однако если пользователь уверен в своих действиях, на компьютере установлена надёжная противовирусная защита, то опасаться такого предупреждения нет смысла.

    Активация всех макросов

    Также включить и отключить макрокоманды в Excel 2007 можно более простым способом, ничем не отличающимся от включения их в Excel 2010.

    Office 2010

    Включить и отключить макрокоманды в Excel 2010 можно, воспользовавшись меню «Разработчик». Однако данное меню не всегда активно в табличном редакторе 2010, особенно в момент первого запуска офисного приложения, поэтому первоначально следует совершить определённые действия, чтобы создать данное меню на панели инструментов. Специалисты рекомендуют выносить на панель инструментов подменю, к которым приходится достаточно часто обращаться в процессе выполнения различных задач.

    Настройка панели инструментов

    Для этого необходимо кликнуть по меню «Файл», далее перейти в «Параметры», а затем в «Настройку ленты». С правой стороны будет находиться список, среди предложенных вариантов пользователь может выбрать те меню, в которых он наиболее часто будет нуждаться, а потому желает, чтобы они постоянно были отображены на панели инструментов. В частности, в этот момент необходимо установить переключатель на строке «Разработчик» и нажать «Ок». После этого данное меню отобразится в верхней части Excel 2010.

    Теперь включить и отключить макрокоманды будет несложно, достаточно будет навести курсор на «Разработчик», далее перейти на строку «Безопасность макросов», после чего откроется уже знакомое меню «Параметры макросов», в котором выбирается последний пункт.

    Панель для работы с макросами

    Проделав все вышеописанные действия по включению макрокоманд, у пользователя уже не возникнут вопросы, как отключить макросы в Excel 2010, поскольку все шаги остаются такими же, только меняется их последовательность на обратную.

    Чтобы создать собственную автоматическую подпрограмму, пользователь должен освоить некоторые азы программирования. Однако если это совершенно невозможно, поскольку нет никаких навыков в этой области, пользователь не настроен на прохождение обучения программированию, можно начать писать макрокоманды, в которых возникла острая необходимость.

    Писать такие команды в Excel 2010 несложно, достаточно кликнуть по строке «Начать запись», а дальше производить те действия, которые ранее выполнялись пользователем, и которые он желал бы осуществлять автоматически. Завершив выполнение действий, нажимается кнопка «Завершить». Теперь созданная подпрограмма будет отображаться в списке доступных, кликнув по ней, запустится процесс, идентичный тому, что был выполнен пользователем вручную.

    Запись макрокоманд в Excel

    Достаточно создать только первую макрокоманду в Excel 2010, как пользователь поймёт, что ничего сложного в этом нет, а также ощутит заметные преимущества, которыми станет сопровождаться его работа. Благодаря этому появляется желание писать новые подпрограммы и совершенствовать процесс выполнения производственных задач.

    Итак, макрокоманды в табличных редакторах 2003, 2007 и 2010 способны восприниматься большинством пользователей в качестве лучших помощников, позволяющих рутинную работу автоматизировать и повысить её результативность.

    Понравилась статья? Поделить с друзьями:
  1. Что такое массив excel 2010
  2. Что такое маппинг в excel
  3. Что такое макросы word 2007
  4. Что такое маска формата ячейки excel
  5. Что такое максимальное значение excel