Microsoft excel макрос книга

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

Создание и обновление книги «Личные макросы»

  1. На вкладке Разработчик в группе Код нажмите кнопку Запись макроса.
    Команда "Записать макрос" в группе "Код" на вкладке "Разработчик"

  2. В диалоговом окне Запись макроса введите содержательное имя макроса в поле Имя макроса. Не используйте пробелы в имени.

  3. В поле Сохранить в выберитеЛичная книга макроса.
    Диалоговое окно записи макроса

  4. Нажмите кнопку ОК.

  5. Выполните действия, которые нужно записать.

  6. На вкладке Разработчик в группе Код нажмите кнопку Остановить запись.
    Команда "Остановить запись" в группе "Код" на вкладке "Разработчик"

  7. Закроем книгу.

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

  8. Нажмите кнопку Сохранить, чтобы сохранить книгу.

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

Общий доступ к макросам

Если вы хотите скопировать макрос из личной книги в другую книгу или наоборот, это можно сделать в редакторе Visual Basic(VBE). Вы можете запустить редактор Visual Basic в Excel, нажав ALT+F11. Дополнительные сведения о копировании макросов из одной книги в другую см. в статье Копирование модуля макроса в другую книгу.

Если вы хотите поделиться файлом Personal.xlsB с другими людьми, вы можете скопировать его в папку XLSTART на других компьютерах. В Windows 10, Windows 7 и Windows Vista эта книга будет сохранена в папке C:Usersимя пользователяAppDataLocalMicrosoftExcelXLStart. В Microsoft Windows XP эта книга сохранена в папке C:Documents and Параметрыимя пользователяApplication DataMicrosoftExcelXLStart. Книги в папке XLStart открываются автоматически при Excel, а все коды, сохраненные в личной книге макроса, будут перечислены в диалоговом окну Макрос.

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

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

В меню Excel выберите пункт Параметры… > ленты & панели инструментов. В категории Настройка ленты в списке Основные вкладки выберите разработчик и нажмите кнопку Сохранить.

Создание и обновление книги «Личные макросы»

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

  1. На вкладке Разработчик нажмите кнопку Запись макроса.

  2. В диалоговом окне Запись макроса введите содержательное имя макроса в поле Имя макроса. Не используйте пробелы в имени.

  3. В поле Сохранить в выберитеЛичная книга макроса.

  4. Нажмите кнопку ОК.

  5. Выполните действия, которые нужно записать.

  6. На вкладке Разработчик щелкните Остановить запись.

  7. Сохраните изменения, закроем книгу и, наконец, закроем Excel.

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

  8. Нажмите кнопку Сохранить, чтобы сохранить книгу.

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

Общий доступ к макросам

Если вы хотите скопировать макрос из личной книги в другую книгу или наоборот, это можно сделать в редакторе Visual Basic(VBE). Чтобы запустить редактор Visual Basic в Excel, щелкните Visual Basic на вкладке Разработчик. Дополнительные сведения о копировании макросов из одной книги в другую см. в статье Копирование модуля макроса в другую книгу.

Если вы хотите поделиться файлом Personal.xlsB с другими людьми, вы можете скопировать его в папку Excel на других компьютерах. Эта папка для Mac находится в домашней папке на сайте ~/Library/Containers/com.microsoft. Excel/Data/Library/Application Support/Microsoft/Roaming/Excel/.

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

Введение

Всем нам приходится — кому реже, кому чаще — повторять одни и те же действия и операции в 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

Большинство пользователей Excel знают, как создать и использовать макрос внутри файла одной рабочей книги. В случаи, когда необходимо использовать тот же макрос в других файлах рабочих книг, тогда можно сохранить его в личной книге макросов. У нее всегда одно название – Personal.xlsb. Она всегда открывается при запуске программы Excel, только скрыто. Данная книга не является доступной по умолчанию в Excel, поэтому ее нужно сначала подключить.

Как сохранить макрос в личную книгу макросов

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

  1. Выберите инструмент: «РАЗРАБОТЧИК»-«Код»-«Запись макроса».
  2. РАЗРАБОТЧИК.

  3. В появившемся диалоговом окне «Запись макроса», из выпадающего списка «Сохранить в:» выберите опцию «Личная книга макросов». И нажмите на кнопку OK.
  4. Запись макроса.

  5. Теперь выберите инструмент: «РАЗРАБОТЧИК»-«Код»-«Остановить запись».
  6. Остановить запись.

  7. Откройте редактор Visual Basic: «РАЗРАБОТЧИК»-«Код»-«Visual Basic». Или нажмите комбинацию горячих клавиш ALT+F11. В окне «Project-VBAProject», в дереве проектов появиться доступная еще одна книга Personal.xlsb. Кликните на «плюсик» слева на против этой книги, чтобы раскрыть проект книги Personal.xlsb. А после двойным щелчком отройте ее Module1.
  8. Personal.xlsb.

  9. В результате откроется окно кода модуля с зарегистрированным макросом. Удалите его код и введите код своего макроса. Выберите инструмент в редакторе макросов: «File»-«Save Personal.xlsb», а потом закройте редактор Visual Basic.



Теперь у вас подключена скрытая книга для хранения макросов, к которым можно получить доступ из любой другой рабочей книги. Личная книга макросов где находится находиться в папке автозагрузки файлов Excel – XLSTART: C:Documents and SettingsUser_NameAppDataRoamingMicrosoftExcelXLSTARTPersonal.xlsb

Примечание. XLSTART – это папка для автозагрузки файлов вместе с запуском программы Excel. Если сохранить файл в данную папку, то он будет открываться вместе с программой Excel. Для версий старше 2007 путь к папке автозагрузки будет следующим: C:Program FilesMicrosoft OfficeOffice12Xlstart.

Если вам нужно записать в нее новый макрос просто откройте редактор, а потом откройте модуль книги Personal.xlsb. Уже записанные в нее макросы удалять не нужно. Они не будут между собой конфликтовать если соблюдать одно простое правило – в одном модуле нельзя хранить макросы с одинаковыми именами.

Автор:

Берндт Г., Каинка Б.

Качество:

хорошее

Автор:

Гарбер Геннадий

Качество:

хорошее

Автор:

Слепцова Л.Д.

Качество:

отличное

Автор:

Джон Уокенбах

Качество:

хорошее

Автор:

Джон Уокенбах

Качество:

хорошее (с примерами файлов)

Автор:

Додж М., Стинсон К.

Качество:

отличное

Автор:

Плакунов М. К.

Качество:

хорошее, текстовый слой

Автор:

Bill Jelen, Tracy Syrstad

Качество:

хорошее

Автор:

Джон Уокенбах

Качество:

отличное (на английском языке)

Автор:

Джон Уокенбах

Качество:

отличное (на английском языке)

Открытие книги Excel из кода VBA. Проверка существования книги. Создание новой книги, обращение к открытой книге и ее закрытие. Методы Open, Add и Close.

Открытие существующей книги

Существующая книга открывается из кода VBA Excel с помощью метода Open:

Workbooks.Open Filename:=«D:test1.xls»

или

Workbooks.Open («D:test1.xls»)

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

Проверка существования файла

Проверить существование файла можно с помощью функции Dir. Проверка существования книги Excel:

If Dir(«D:test1.xls») = «» Then

    MsgBox «Файл не существует»

Else

    MsgBox «Файл существует»

End If

Или, если файл (книга Excel) существует, можно сразу его открыть:

If Dir(«D:test1.xls») = «» Then

    MsgBox «Файл не существует»

Else

    Workbooks.Open Filename:=«D:test1.xls»

End If

Создание новой книги

Новая рабочая книга Excel создается в VBA с помощью метода Add:

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

Workbooks.Add

ActiveWorkbook.SaveAs Filename:=«D:test2.xls»

В кавычках указывается полный путь сохраняемого файла Excel, включая присваиваемое имя, в примере — это «test2.xls».

Обращение к открытой книге

Обращение к активной книге:

Обращение к книге с выполняемым кодом:

Обращение к книге по имени:

Workbooks(«test1.xls»)

Workbooks(«test2.xls»)

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

Открытая рабочая книга закрывается из кода VBA Excel с помощью метода Close:

Workbooks(«test1.xlsx»).Close

Если закрываемая книга редактировалась, а внесенные изменения не были сохранены, тогда при ее закрытии Excel отобразит диалоговое окно с вопросом: Вы хотите сохранить изменения в файле test1.xlsx? Чтобы файл был закрыт без сохранения изменений и вывода диалогового окна, можно воспользоваться параметром метода Close — SaveChanges:

Workbooks(«test1.xlsx»).Close  SaveChanges:=False

или

Workbooks(«test1.xlsx»).Close  (False)

Закрыть книгу Excel из кода VBA с сохранением внесенных изменений можно также с помощью параметра SaveChanges:

Workbooks(«test1.xlsx»).Close  SaveChanges:=True

или

Workbooks(«test1.xlsx»).Close (True)


Фразы для контекстного поиска: открыть книгу, открытие книги, создать книгу, создание книги, закрыть книгу, закрытие книги, открыть файл Excel, открытие файла Excel, существование книги, обратиться к открытой книге.


Содержание

  • 1 Как сохранить макрос в личную книгу макросов
    • 1.1 Как создать Личную Книгу Макросов
    • 1.2 Как использовать Личную Книгу Макросов
    • 1.3 Где хранится Личная Книга Макросов
    • 1.4 P.S.
    • 1.5 Ссылки по теме

Большинство пользователей Excel знают, как создать и использовать макрос внутри файла одной рабочей книги. В случаи, когда необходимо использовать тот же макрос в других файлах рабочих книг, тогда можно сохранить его в личной книге макросов. У нее всегда одно название – Personal.xlsb. Она всегда открывается при запуске программы Excel, только скрыто. Данная книга не является доступной по умолчанию в Excel, поэтому ее нужно сначала подключить.

Как сохранить макрос в личную книгу макросов

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

  1. Выберите инструмент: «РАЗРАБОТЧИК»-«Код»-«Запись макроса».
  2. В появившемся диалоговом окне «Запись макроса», из выпадающего списка «Сохранить в:» выберите опцию «Личная книга макросов». И нажмите на кнопку OK.
  3. Теперь выберите инструмент: «РАЗРАБОТЧИК»-«Код»-«Остановить запись».
  4. Откройте редактор Visual Basic: «РАЗРАБОТЧИК»-«Код»-«Visual Basic». Или нажмите комбинацию горячих клавиш ALT+F11. В окне «Project-VBAProject», в дереве проектов появиться доступная еще одна книга Personal.xlsb. Кликните на «плюсик» слева на против этой книги, чтобы раскрыть проект книги Personal.xlsb. А после двойным щелчком отройте ее Module1.
  5. В результате откроется окно кода модуля с зарегистрированным макросом. Удалите его код и введите код своего макроса. Выберите инструмент в редакторе макросов: «File»-«Save Personal.xlsb», а потом закройте редактор Visual Basic.

Теперь у вас подключена скрытая книга для хранения макросов, к которым можно получить доступ из любой другой рабочей книги. Личная книга макросов где находится находиться в папке автозагрузки файлов Excel – XLSTART: C:Documents and SettingsUser_NameAppDataRoamingMicrosoftExcelXLSTARTPersonal.xlsb

Примечание. XLSTART – это папка для автозагрузки файлов вместе с запуском программы Excel. Если сохранить файл в данную папку, то он будет открываться вместе с программой Excel. Для версий старше 2007 путь к папке автозагрузки будет следующим: C:Program FilesMicrosoft OfficeOffice12Xlstart.

Если вам нужно записать в нее новый макрос просто откройте редактор, а потом откройте модуль книги Personal.xlsb. Уже записанные в нее макросы удалять не нужно. Они не будут между собой конфликтовать если соблюдать одно простое правило – в одном модуле нельзя хранить макросы с одинаковыми именами.

Если вы еще не знакомы с макросами в Excel, то я вам даже немного завидую. Ощущение всемогущества и осознание того, что ваш Microsoft Excel можно прокачивать почти до бесконечности, которые придут к вам после знакомства с макросами — приятные чувства.

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

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

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

А если макрос должен быть относительно универсален и нужен в любой книге Excel — как, например, макрос для конвертирования формул в значения? Не копировать же его код на Visual Basic каждый раз в каждую книгу? Кроме того, рано или поздно, почти любой пользователь приходит к мысли, что неплохо было бы сложить все макросы в одну коробку, т.е. иметь их всегда под рукой. И может быть даже запускать не вручную, а сочетаниями клавиш? И вот тут может здорово помочь Личная Книга Макросов (Personal Macro Workbook).

Как создать Личную Книгу Макросов

На самом деле, Личная Книга Макросов (ЛКМ) — это обычный файл Excel в формате двоичной книги (Personal.xlsb), который автоматически в скрытом режиме открывается одновременно с Microsoft Excel. Т.е. когда вы просто запускаете Excel или открываете любой файл с диска, на самом деле открываются два файла — ваш и Personal.xlsb, но второго мы не видим. Таким образом все макросы, которые хранятся в ЛКМ оказываются доступы для запуска в любой момент, пока открыт Excel.

Если вы еще ни разу не пользовались ЛКМ, то изначально файл Personal.xlsb не существует. Самый легкий способ его создать — это записать рекордером какой-нибудь ненужный бессмысленный макрос, но указать в качестве места для его хранения Личную Книгу — тогда Excel будет вынужден автоматически ее для вас создать. Для этого:

  1. Откройте вкладку Разработчик (Developer). Если вкладки Разработчик не видно, то ее можно включить в настройках через Файл — Параметры — Настройка ленты (Home — Options — Customize the Ribbon).
  2. На вкладке Разработчик нажмите кнопку Запись макроса (Record Macro). В открывшемся окне выберите Личную книгу макросов (Personal Macro Workbook) как место для хранения записанного кода и нажмите OK:

    как сделать общий макрос excel для всей системы

  3. Остановите запись кнопкой Остановить запись (Stop Recording) на вкладке Разработчик (Developer)

Проверить результат можно, нажав на кнопку Visual Basic там же на вкладке Разработчик — в открывшемся окне редактора в левом верхнем углу на панели Project — VBA Project должен появиться наш файл PERSONAL.XLSB. Его ветку которого можно развернуть плюсиком слева, добравшись до Module1, где и хранится код только что записанного нами бессмысленного макроса:

как сделать общий макрос excel для всей системы

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

Как использовать Личную Книгу Макросов

Дальше все просто. Любой нужный вам макрос (т.е. кусок кода, начинающийся на Sub и заканчивающийся End Sub) можно смело копировать и вставлять либо в Module1, либо в отдельный модуль, добавив его предварительно через меню Insert — Module. Хранить все макросы в одном модуле или раскладывать по разным — исключительно вопрос вкуса. Выглядеть это должно примерно так:

как сделать общий макрос excel для всей системы

Запустить добавленный макрос можно в диалоговом окне, вызываемом с помощью кнопки Макросы (Macros) на вкладке Разработчик:

как сделать общий макрос excel для всей системы

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

Кроме обычных макросов-процедур в Личной Книге можно хранить и пользовательские макро-функции (UDF = User Defined Function). В отличие от процедур, код функций начинаются с оператора Function или Public Function, а заканчиваются на End Function:

как сделать общий макрос excel для всей системы

Код необходимо аналогичным образом скопировать в любой модуль книги PERSONAL.XLSB и затем можно будет вызвать функцию обычным образом, как любую стандарную функцию Excel, нажав кнопку fx в строке формул и выбрав функцию в окне Мастера Функций в категории Определенные пользователем (User Defined):

как сделать общий макрос excel для всей системы

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

Где хранится Личная Книга Макросов

Если вы будете использовать Личную Книгу Макросов, то рано или поздно у вас возникнет желание:

  • поделиться своими накопленными макросами с другими пользователями
  • скопировать и перенести Личную Книгу на другой компьютер
  • сделать ее резервную копию

Для этого нужно будет найти файл PERSONAL.XLSB на диске вашего компьютера. По умолчанию, этот файл хранится в специальной папке автозапуска Excel, которая называется XLSTART. Так что все, что нужно — это добраться до этой папки на нашем ПК. И вот тут возникает небольшая сложность, потому что местоположение этой папки зависит от версии Windows и Office и может различаться. Обычно это один из следующих вариантов:

  • C:Program FilesMicrosoft OfficeOffice12XLSTART
  • C:Documents and SettingsComputerApplication DataMicrosoftExcelXLSTART
  • C:Usersимя-вашей-учетной-записиAppDataRoamingMicrosoftExcelXLSTART

Как вариант, можно спросить о положении этой папки сам Excel с помощью VBA. Для этого в редакторе Visual Basic (кнопка Visual Basic на вкладке Разработчик) нужно открыть окно Immediate сочетанием клавиш Ctrl+G, ввести туда команду ? Application.StartupPath и нажать на Enter:

как сделать общий макрос excel для всей системы

Полученный путь можно скопировать и вставить в верхнюю строку окна Проводника в Windows и нажать Enter — и мы увидим папку с нашим файлом Личной Книги Макросов:

как сделать общий макрос excel для всей системы

P.S.

И несколько практических нюансов вдогон:

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

Ссылки по теме

  • Что такое макросы, как их использовать в работе
  • Полезности для VBA-программиста
  • Тренинг «Программирование макросов на VBA в Microsoft Excel»

Создание новой книги макросом

​Смотрите также​​ = tmp ‘вернуть​ мы передадим ей​ назначить кнопке макрос,​
​ при старте Excel​ Record New Macro)​- это небольшая​- доступен через​ Customize Ribbon)​ и те же​ наш метод. Наш​ New Excel.Application ‘Запускаем​ тот лист который​ New_Wb.SaveAs ThisWorksbook.Sheets(«1 норм»).Range(«O6»)​ явно:​
​ String, sAddress As​ Set objThisBook =​evgeniy_m​ значение свойстваКстати, добавлять​ как аргументы (исходные​ выбрать другой значок​ и могут быть​
​в Excel 2007 и​

​ программа, встроенная в​​ Project Explorer и​и включаем в​
​ действия по обработке​ метод — как​ Excel​

​ копируется (лист «Смета»),​​ & «» &​New_Wb.SaveAs Range(«O6») &​ String, vData Dim​ GetObject.ActiveWorkbook sAddress =​: Доброе время суток.​ листы в существующую​ данные для расчета).​

​ и имя:​​ запущены в любой​

​ новее — нажать​​ Excel, которая переводит​ через контекстное меню​ правой части окна​ поступивших данных, заполнение​

​ у​​oExcel.Visible = True​ то как прописать​ ThisWorksbook.Sheets(«1 норм»).Range(«Книга») &​ «» & Range(«Книга»)​

​ objThisBook As Object​​ «A1:AA6000» vData =​

​ Есть книга, в​​ книгу тоже можно​

​Чтобы создать пользовательскую функцию​​Кнопка на панели быстрого​ момент и в​ кнопку​ любое действие пользователя​

​ листа, т.е. правой​​ флажок​ однообразных таблиц или​
​alex77755​ ‘Делаем его видимым​ макрос, чтобы он​ «.xlsm», 52​ & «.xlsm», 52​ Set objThisBook =​ objCloseBook.Sheets(«plan»).Range(sAddress).Value objThisBook.Close False​ ячейке А1 значение.​ не по одному:​ для расчета, например,​ доступа в Excel​
​ любой книге.​Запись макроса (Record macro)​ на язык программирования​ кнопкой мыши по​Разработчик (Developer)​ бланков и т.д.​. Я его дополнительно​Dim oWbk As​ все делал то​new_see​52 — формат​ GetObject(«d:test.xls») sAddress =​ Sheets(«plan_191»).Range(«A1»).Resize(UBound(vData, 1), UBound(vData,​Sub New2() Dim​ Sheets.Add after:=ActiveSheet, Count:=200Параметр​ налога на добавленную​ 2007 и новее​

​После включения записи и​​на вкладке​ VBA и записывает​ ярлычку листа -​. Теперь на появившейся​:)

​ Использование макросов и​​ раскрасил множественными областями:​ Excel.Workbook ‘Создаем новую​ же самое, за​: Как создать новую​ xslm.​ «A1:AA6000» vData =​ 2)).Value = vDataно​ New_Wb As Workbook​

​ Count тоже в​​ стоимость (НДС) откроем​Щелкните правой кнопкой мыши​ выполнения действий, которые​
​Разработчик (Developer)​ получившуюся команду в​ команда​ вкладке нам будут​
​ пользовательских функций позволяет​200?’200px’:»+(this.scrollHeight+5)+’px’);»>Sub copy2()​ книгу Книга1​ исключением копирования данной​ книгу с заданным​Honey​ objThisBook.Sheets(«abs_plan»).Range(sAddress).Value Sheets(«abs_plan_191»).Range(«A1»).Resize(UBound(vData, 1),​

​ на строке Set​​ Set New_Wb =​ пределах 1..255.​ редактор VBA, добавим​ по панели быстрого​ необходимо записать, запись​Затем необходимо настроить параметры​ программный модуль. Если​Исходный текст (View Source)​
​ доступны основные инструменты​:)

​ автоматизировать эти операции,​​Dim oSheetAs Worksheet​Set oWbk =​ кнопки. Проще говоря​ именем?​

​: The_Prist, спасибо, что​​ UBound(vData, 2)).Value =​ objThisBook = GetObject.ActiveWorkbook​ Workbooks.Add New_Wb.Activate New_Wb.SaveAs​Hugo121​

​ новый модуль через​​ доступа в левом​ можно остановить командой​ записываемого макроса в​ мы включим макрорекордер​

​. Сюда записывают макросы,​​ для работы с​ перекладывая монотонную однообразную​Dim srcRange As​ oExcel.Workbooks.Add()​ — без этой​Например​

​ откликнулись!​​ vDataВот написал, все​ дает ошибку…. как​ («D:test» & «1»​: На практике обычно​ меню​ верхнем углу окна​Остановить запись​ окне​ на запись, а​ которые должны выполняться​ макросами, в том​ работу на плечи​ Range​

​Dim oSheet As​​ кнопки.​
​Sub CreateWorkbook() Set​Ошибка Runtime error​ отлично работает, но​ мне указать, что​ & «.xls») New_Wb.Close​ нужно​Insert — Module​ Excel и выберите​

​(Stop Recording)​​Запись макроса​ затем начнем создавать​

​ при наступлении определенных​​ числе и нужная​

​ Excel. Другим поводом​​Dim areaAs Range​
​ Excel.Worksheet​Прикрепил файл​ NewWorkbook = Workbooks.Add​ 1004:: Method ‘Range’​ копирует без сохранения​ нужно копировать лист​ End SubЗапускаю макрос,​Set xlWb =​и введем туда​
​ команду​.​
​:​ свой еженедельный отчет,​ событий на листе​ нам кнопка​ для использования макросов​Set srcRange =​
​Set oSheet =​
​gling​ End Subсоздает книгу​ of Global Failed​ параметров ячеек…​ из книги откуда​ создается новая книга​ Workbooks.Add(1) ‘создать книгу​
​ текст нашей функции:​

​Настройка панели быстрого доступа​​Управление всеми доступными макросами​
​Имя макроса​ то макрорекордер начнет​ (изменение данных в​Редактор Visual Basic​
​ в вашей работе​ Intersect(ActiveSheet.UsedRange, _​:(

​ oWbk.Worksheets.Item(«Лист1») ‘Находим Лист1​​: Пропишите так​ с именем по​
​The_Prist​Johny​ запускался макрос….?​ сохраняется по пути​ с одним листомДалее​
​Обратите внимание, что в​ (Customise Quick Access​ производится в окне,​
​- подойдет любое​ записывать команды вслед​ ячейках, пересчет листа,​
​(Visual Basic Editor)​ может стать необходимость​Range(«A:H,S:S,U:U,W:W,AQ:AQ,AE:AE,AF:AF,AY:AY,BA:BA,BG:BG,BH:BH,BI:BI»))​
​oSheet.Name = «Новый​200?’200px’:»+(this.scrollHeight+5)+’px’);»>shSmeta.Copy Before:=bkNew.Sheets(1)​

​ умолчанию,​​: А Вы вдумайтесь​: Так?​
​Johny​ D:test, присваивается имя​ можно листы добавить,​

​ отличие от макросов​​ Toolbar)​ которое можно открыть​ имя на русском​ за каждым нашим​ копирование или удаление​:​ добавить в Microsoft​Set oSheet =​ лист» ‘Присваиваем ему​ActiveSheet.Shapes(«Button 1»).Delete​
​а как изменить​ в ошибку. В​Sub F() Dim​: Ничего не понятно​ 1.xls и закрывается.​ но это нужно​ функции имеют заголовок​:​ с помощью кнопки​ или английском языке.​ действием и, в​ листа и т.д.)​
​К сожалению, интерфейс редактора​ Excel недостающие, но​

​ Workbooks.Add.Worksheets(«Лист1») ‘Создаем новую​​ имя «Новый лист»​bkNew.SaveAs ThisWorkbook.Path &​ имя, чтобы создалась​

​ Google-переводчик закиньте. Тогда​​ wkbNew As Workbook​
​ (а в приложенном​Проблема в следующем,​ редко.​Function​Затем в открывшемся окне​Макросы (Macros)​ Имя должно начинаться​ итоге, мы получим​Обычный макрос, введенный в​ VBA и файлы​ нужные вам функции.​ книгу и находим​Dim oRange As​ «» & CStr(shAct.Range(«B19»).Value)​
​ не ‘Книга1’,​

​ видно будет, что​​ Sheets(«plan»).Copy Set wkbNew​ макросе вообще какая-то,​ как переписать макрос,​Serg_FSM​вместо​ выберите категорию​на вкладке​ с буквы и​ макрос создающий отчет​ стандартный модуль выглядит​ справки не переводятся​ Например функцию сборки​ Лист1​ Range ‘Находим диапазон​ & «.xlsx»​а например ‘Моя​ у Вас проблема​ = ActiveWorkbook wkbNew.Sheets(1).Name​ извините, ерунда).​ чтобы новая книга​: Приветствую.​

planetaexcel.ru

Как создать новую книгу с заданным именем?

​Sub​​Макросы​Разработчик (Developer)​ не содержать пробелов​
​ как если бы​
​ примерно так:​ компанией Microsoft на​ данных с разных​oSheet.Name = «Новый​ A1 в Книга1​
​bkNew.Close​ книга’​ в том, что​
​ = «plan_191» wkbNew.SaveAs​Юрий М​

​ сохранялась с названием​​Помогите с такой​и непустой список​

​и при помощи​

CyberForum.ru

Создание новой книги (название книги из ячейки) (Макросы/Sub)

​или — в​​ и знаков препинания.​ он был написан​Давайте разберем приведенный выше​ русский язык, поэтому​
​ листов на один​
​ лист» ‘Присваиваем ему​Set oRange =​Но думаю что​new_see​ нет диапазона «Книга»​ «D:test» & ThisWorkbook.Sheets(«Лист1»).Range(«A1»)​: Sub New2() Dim​
​ как в ячейке​ проблемой: нужно програмно​ аргументов (в нашем​ кнопки​ старых версиях Excel​Сочетание клавиш​
​ программистом. Такой способ​ в качестве примера​ с английскими командами​ итоговый лист, разнесения​ имя «Новый лист»​
​ oSheet.Range(«A1»)​ лучше кнопку и​: NewWorkbook.Windows(1).Caption = ‘Моя​ или «Об» или​ & «.xls» End​ New_Wb As Workbook​
​ А1 книги, с​
​ создать новую рабочую​

​ случае это​​Добавить (Add)​​ - через меню​- будет потом​ создания макросов не​
​ макрос​ в меню и​
​ данных обратно, вывод​For Each area​’———-На данном этапе​

​ список выбора сметы​​ книга’​

​ другого, чего Вы​​ Sub​​ Set New_Wb =​​ которой запускается макрос?​​ книгу Excel, но​​Summa​перенесите выбранный макрос​
​Сервис — Макрос -​ использоваться для быстрого​ требует знаний пользователя​Zamena​ окнах придется смириться:​ суммы прописью и​ In srcRange.Areas​ я хочу вставить​ разместить вверху сметы.​спасибо​ пишите в Range.​Юрий М​
​ Workbooks.Add ThisWorkbook.Sheets(«plan»).Copy New_Wb.Sheets.Add​

​Заранее спасибо!​​ при этом с​​). После ввода кода​
​ в правую половину​
​ Макросы​ запуска макроса. Если​ о программировании и​
​:​

​Макросы (т.е. наборы команд​ т.д.​area.Copy oSheet.Range(area.Address)​ данные из буфера​ Кнопку привязать к​den45444​Так же надо​: evgeniy_m, Вы читаете,​ After:=New_Wb.Sheets(Sheets.Count) New_Wb.SaveAs («D:test»​Alexander88​ определенным именем (а​

​ наша функция становится​​ окна, т.е. на​​(Tools — Macro -​​ забудете сочетание или​

​ VBA и позволяет​​Любой макрос должен начинаться​​ на языке VBA)​
​Макрос​Next​
​oRange.Value = "Начиная​
​ строкам и при​: Есть макрос на​
​ помнить, что указание​
​ что Вам пишут?​

excelworld.ru

Как вставить данные из старой книги в новую созданную книгу (Макросы/Sub)

​ & ThisWorkbook.Sheets(«Лист1»).Range(«A1») &​​: Попробуйте заменить пятую​
​ не тем что​ доступна в обычном​ панель быстрого доступа:​ Macros)​ вообще его не​
​ пользоваться макросами как​ с оператора​ хранятся в программных​- это запрограммированная​End Sub​ с этой ячейки​ копировании сметы удалять​ создание новой книги.​ Range явного указания​evgeniy_m​ «.xls») New_Wb.Close End​
​ строку на:​ Excel предлагает по​
​ окне Мастера функций​
​Кнопка на листе​
​:​ введете, то макрос​ неким аналогом видеозаписи:​
​Sub​
​ модулях. В любой​
​ последовательность действий (программа,​Дмитрий_С​
​ я хочу вставить​
​ верхнею строку или​
​ Его нужно немного​
​ для него листа​: Johny, спасибо!​ Sub​
​New_Wb.SaveAs ("D:test" &​ умолчанию), без использования​
​ (​Этот способ подходит для​Любой выделенный в списке​
​ можно будет запустить​ включил запись, выполнил​
​, за которым идет​ книге Excel мы​
​ процедура), записанная на​: Благодаря твоему коду​
​ диапазон из буфера"​ строки. Удалится и​ изменить под условие.​
​ и книги подразумевает​Honey​Hugo​
​ Cells(1, 1) &​ шаблона и без​
​Вставка - Функция​ любой версии Excel.​ макрос можно запустить​
​ через меню​ операци, перемотал пленку​ имя макроса и​ можем создать любое​ языке программирования Visual​ оказалось что не​
​ 'вносим в него​

​ список и кнопка​Подробно:​
​ обращение к АКТИВНОЙ​

​: Всем привет!​​: скопировать лист (plan)​ «.xls»)​ сохранения файла. Нужно​) в категории​ Мы добавим кнопку​ кнопкой​Сервис — Макрос -​ и запустил выполнение​

​ список аргументов (входных​​ количество программных модулей​​ Basic for Applications​
​ надо!​ данные​
​ вызова макроса.​- Есть книга​
​ книге. А Вы​Надеюсь мой вопрос​
​ в эту новую​Юрий М​
​ это вот для​Определенные пользователем (User Defined)​
​ запуска макроса прямо​Выполнить​
​ Макросы - Выполнить​ тех же действий​ значений) в скобках.​
​ и разместить там​ (VBA). Мы можем​Цитата​
​End Sub​
​den45444​

​ и в этой​​ её только что​ здесь уместен. Я​

​ книгу -​​: Sub New2() Dim​ чего: обработчик события​:​ на рабочий лист,​(Run)​(Tools — Macro -​ еще раз. Естественно​ Если аргументов нет,​ наши макросы. Один​ запускать макрос сколько​​Gustav, 14.01.2015 в​​Читаем внимательно правила​:​
​ книги есть лист​
​ создали. Следовательно там​
​ под основу взяла​sheets("plan").copy получите новую​
​ New_Wb As Workbook​
​ проверяет есть ли​После выбора функции выделяем​
​ как графический объект.​
​.​ Macros - Run)​ у такого способа​ то скобки надо​
​ модуль может содержать​ угодно раз, заставляя​ 15:45, в сообщении​
​ форума​gling​
​ "Смета" и есть​
​ НЕТ ИМЕНОВАННЫХ ДИАПАЗОНОВ,​
​ код, предлагаемый здесь.​

​ книгу с одним​​ Set New_Wb =​ среди открытых книг​ ячейки с аргументами​specool
​ Для этого:​​Кнопка​или с помощью​ есть свои плюсы​ оставить пустыми.​ любое количество макросов.​
​ Excel выполнять последовательность​ № 5200?’200px’:»+(this.scrollHeight+5)+’px’);»>Я его​Особенно п.п.3​
​, Благодарю за помощь.​​ кнопка на другом​​ да и вообще​ Но его чуток​ листом, который затем​ Workbooks.Add New_Wb.Activate New_Wb.SaveAs​ книга с определенным​ (с суммой, для​В Excel 2003 и​Параметры​ кнопки​ и минусы:​Любой макрос должен заканчиваться​ Доступ ко всем​victory

​ любых нужных нам​​ дополнительно раскрасил множественными​Hugo​
​RAN​
​ листе "создать новую​ данных.​
​ видоизменила. И теперь​ можете переименовать.​ ("D:test" & ThisWorkbook.Sheets("Лист1").Range("A1")​
​ именем, если есть​ которой надо посчитать​
​ старше - откройте​
​(Options)​

excelworld.ru

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

Введение

​Макросы (Macros)​Макрорекордер записывает только те​ оператором​ модулям осуществляется с​ действий, которые нам​ областями:​: В новый эксель​:​ смету».​Советую очень внимательно​ у меня проблема-выдает​Только при таком​ & «.xls») New_Wb.Close​ он добавляет в​ НДС) как в​ панель инструментов​позволяет посмотреть и​на вкладке​ действия, которые выполняются​End Sub​ помощью окна Project​ не хочется выполнять​Красиво раскрасил, но​ вставить скопированные столбцы​200?’200px’:»+(this.scrollHeight+5)+’px’);»>Sub Макрос1()​- Нажимая на​ изучить:​ ошибку на строку​ копировании пострадают длинные​ End Sub​ нее новые данные,​ случае с обычной​Формы​ отредактировать сочетание клавиш​Разработчик (Developer)​

​ в пределах окна​​.​ Explorer в левом​ вручную.​ оказалось достаточным кода​ будет проблематично -​’ отключить копирование​ этот макрос, создается​Honey​ New_Wb.SaveAs​ строки в ячейках,​evgeniy_m​ если нет, то​ функцией:​

​через меню​ для быстрого запуска​или нажав ALT+F8.​ Microsoft Excel. Как​Все, что находится между​ верхнем углу редактора​В принципе, существует великое​ у alex77755)​ вставляйте в тот​ объектов​ новая книга и​: Во вложении файл,​А сам код​ если они конечно​

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

​: ошибку дает (​ он сначала ее​PuLbKa​Вид — Панели инструментов​ макроса.​Сохранить в…​ только вы закрываете​

  • ​Sub​ (если его не​ множество языков программирования​Друзья,​​ же эксель. Т.е.​Application.CopyObjectsWithCells = False​ ​ лист «Смета» копируется​ в котором этот​​ вот​
  • ​ есть. Хотя в​Юрий М​ создает и затем​: Не могу понять​​ — Формы (View​​Кнопка​​- здесь задается​ Excel или переключаетесь​и​ видно, нажмите CTRL+R).​​ (Pascal, Fortran, C++,​огромное спасибо​ Ваш код почти​​’ включить копирование​​ в эту книгу,​ самый макрос (модуль)​Dim New_Wb As​ новых экселях не​: Это не информация​ добавляет данные.​ как задать количество​​ — Toolbars -​ ​Изменить​

    Excel vba создание новой книги​ место, куда будет​

​ в другую программу​End Sub​ Программные модули бывают​ C#, Java, ASP,​за помощь! Я​ полностью не годится,​ объектов​ сохраняет и закрывает.​

Excel vba создание новой книги

​Honey​ Workbook Set New_Wb​ проверял…​ — всегда следует​serb​ страниц при создании​ Forms)​(Edit)​ сохранен текст макроса,​ — запись останавливается.​- тело макроса,​ нескольких типов для​ PHP…), но для​ недели две блуждал​ нужно переписывать.​Application.CopyObjectsWithCells = True​- Название новой​: The_Prist,​ = Workbooks.Add New_Wb.Activate​evgeniy_m​ указывать — КАКУЮ​

  • ​: Создайте новую процедуру​​ нового excel-файла​В Excel 2007 и​открывает редактор Visual​ т.е. набор команд​Макрорекордер может записать только​ т.е. команды, которые​​ разных ситуаций:​​ всех программ пакета​ в интернете и​alex77755​End Sub​ книги указывается в​Об этом я​ New_Wb.SaveAs (Range(«O6») &​: Суть такая, открываю​ ошибку получаете.​ УпрЛабРаб9, которая должна​
    Excel vba создание новой книги
  • ​Содаю я его​​ новее — откройте​ Basic (см. выше)​ на VBA из​ те действия, для​ будут выполняться при​Обычные модули​ Microsoft Office стандартом​ не мог найти​:​Дмитрий_С​ самом макросе, т.е.​ читала… Видимо, действительно,​ «» & Range(«Книга»)​
    Excel vba создание новой книги
  • ​ книгу, запускаю макрос,​​Alexander88​ выполнить следующие действия:​ так​ выпадающий список​ и позволяет просмотреть​ которых и состоит​ которых есть команды​​ запуске макроса. В​​- используются в​ является именно встроенный​ подходящий код, все​200?’200px’:»+(this.scrollHeight+5)+’px’);»>Public Sub nytfjdkt()​: Добрый день!​ всегда под одним​ я чего-то не​ & «.xlsm»)​
    Excel vba создание новой книги

​ создается новая книга​: И пример Юрия​• создать новую​

Excel vba создание новой книги

​Dim xlWb As​Вставить (Insert)​ и отредактировать текст​​ макрос.:​​ меню или кнопки​

  • ​ данном случае макрос​ большинстве случаев, когда​​ язык VBA. Команды​​ остальные не подходили,​Dim oWbk As​У меня имеется​ названием.​ понимаю((( У меня​либо​ и лист в​
  • ​ с указанием откуда​ рабочую книгу;​​ Excel.Workbook Set xlWb​​на вкладке​
  • ​ макроса на VBA.​​Эта книга​​ в Excel. Программист​​ выделяет ячейку заливает​​ речь идет о​ этого языка понимает​ а ошибку в​ Excel.Workbook​ файл из которого​А мне нужно​ есть такие диапазоны.​Dim New_Wb As​ ней. Теперь из​ берется ячейка не​• вставить в​ = Workbook.Add​Разработчик (Developer)​Чтобы не запоминать сочетание​- макрос сохраняется​

​ же может написать​ выделенных диапазон (Selection)​ макросах. Для создания​ любое офисное приложение,​ них я не​Dim oSheet As​ мне необходимо скопировать​ так, чтобы название​ И я ведь​ Workbook Set New_Wb​ 1-й книги нужно​ работает?​ эту книгу новый​Все получилось​ ​ клавиш для запуска​ в модуль текущей​ макрос, который делает​ желтым цветом (код​

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

​ такого модуля выберите​​ будь то Excel,​ мог найти. Данный​ Excel.Worksheet​ некоторые столбцы в​ новой книги бралось​ указываю на имена​ = Workbooks.Add New_Wb.Activate​ скопировать лист в​evgeniy_m​ рабочий лист;​S.V.I.N.​Выберите объект​ макроса, лучше создать​ книги и, как​ то, что Excel​ = 6) и​ в меню​ Word, Outlook или​ код это именно​Dim Sh As​ новую созданную книгу.​ с ячейки (в​ диапазонов не в​ New_Wb.SaveAs («M:ProductionМастера2017Нормализация» &​ новую книгу.​: макрос не компилируеться..​• дать новому​: Количество страниц можно​Кнопка (Button):​ кнопку и назначить​ следствие, будет выполнятся​ никогда не умел​ затем проходит в​Insert — Module​ Access.​

  • ​ то, что мне​ Excel.Worksheet​Данный код нашел​ примере видно -​ ново-созданной книге. Или​ Range(«имя_папки»).Value & «»​Помогите пожалуйста​Юрий М​
  • ​ рабочему листу ваше​ увеличивать следующим образом.​Затем нарисуйте кнопку на​ ей нужный макрос.​ только пока эта​ (сортировку по цвету,​ цикле по всем​. В появившееся окно​Для ввода команд и​ надо. Всё работает!​Set Sh =​ в интернете, не​
  • ​ ячейка E7)​ как мне конкретней​ & Range(«Книга») &​Юрий М​: Мой вариант проверяли?​ имя;​for i=0 to​ листе, удерживая левую​ Кнопка может быть​ книга открыта в​ например или что-то​ ячейкам, заменяя формулы​ нового пустого модуля​ формирования программы, т.е.​Hugo​

​ ActiveSheet​

  • ​ могу в нем​Пример прикрепляю.​ указать, чтобы диапазон​​ «.xlsm»)​: Согласен с Johny:​ ​The_Prist​• сохранить рабочую​
  • ​ x With New_Ex​ кнопку мыши. Автоматически​ нескольких типов:​​ Excel​​ подобное).​​ на значения. В​

​ можно вводить команды​ создания макроса необходимо​: Т.е. нужно было​​Set oWbk =​​ сделать новую книгу​

Excel vba создание новой книги

  • ​Жду помощи.​​ брался конкретно с​Спасибо​ ерунда получается -​: evgeniy_m, Лист1 в​ книгу под именем​ Sheets.Add After:=Sheets(Sheets.Count) end​ появится окно, где​
  • ​Кнопка на панели инструментов​​Новая книга​Если во время записи​ конце выводится окно​ на VBA, набирая​ открыть специальное окно​ только вот это?​ Workbooks.Add()​ активной чтобы в​​ShAM​ первоначальной книги для​ ​Honey​ сначала имя листа​​ книге с макросом​ УпрЛабРаб9.​​ With next iгде​​ нужно выбрать макрос,​​ в Excel 2003​​- макрос сохраняется​
  • ​ макроса макрорекордером вы​​ сообщения (MsgBox).​ их с клавиатуры​ — редактор программ​200?’200px’:»+(this.scrollHeight+5)+’px’);»>Sub tt()​Set oSheet =​ ней работать, например​: Замените:​
    • ​ именования…?​​: Люди добрые!​ «plan», затем «plan_191″…​ присутствует? Что означает​Выполните процедуру. Откройте​ х — это​ который должен запускаться​ и старше​
    • ​ в шаблон, на​​ ошиблись — ошибка​С ходу ясно, что​ или копируя их​ на VBA, встроенный​Dim r As​ oWbk.Worksheets(«Лист1″) ‘Находим Лист1​ как вставить данные​200?’200px’:»+(this.scrollHeight+5)+’px’);»>Const strNewBook As String​Спасибо за ссылочку))​Помогите с проблемой​Юрий М​
    • ​ «макрос не компилируется»?​​ рабочую книгу УпрЛабРаб9​ кол-во циклов (требуемое​ при щелчке по​​Откройте меню​​ основе которого создается​ будет записана. Однако​ вот так сразу,​​ из другого модуля,​​ в Microsoft Excel.​ Range​oSheet.Name = «Новый​ из буфера обмена,​ = «Смета-1.xlsx» ‘имя​The_Prist​

​ выше, пожалуйста… Интернет​: evgeniy_m, у Дмитрия​evgeniy_m​ и введите несколько​​ кол-во листов)​ ​ нарисованной кнопке.​​Сервис — Настройка​

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

​ любая новая пустая​ смело можете давить​ без предварительной подготовки​ с этого сайта​​В старых версиях (Excel​​’——Копирование столбцов из​​ лист» ‘Присваиваем ему​​ т.к. активной книгой​ нового файла​: нет. Я же​​ обыскала ничего не​ (The_Prist) очень хороший​ ​: супер! Огромное спасибо​ значений в рабочий​​Казанский​

Excel vba создание новой книги

  • ​Создание пользовательских функций или,​(Tools — Customize)​ книга в Excel,​​ на кнопку отмены​ ​ и опыта в​​ или еще откуда​
  • ​ 2003 и старше)​​ старой книги в​ ​ имя «Новый лист»​​ остается та из​на: Код200?’200px’:»+(this.scrollHeight+5)+’px’);»>Dim strNewBook​ написал, что указание​ получается(((​
  • ​ текст в подписи​​ !​ ​ лист с вашим​​: Ладно, раз ТС​ как их иногда​и перейдите на​ т.е. макрос будет​ последнего действия (Undo)​

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

​ программировании вообще и​ нибудь:​ для этого идем​ новую книгу———-​’——Копирование столбцов из​ которой копирую столбцы​ As String​

​ Range без явного​Вся надежда на​ — прочитайте))​

​ПОмогите еще с​​ именем. Создайте новую​ ​ не написал, что​​ еще называют, UDF-функций​ вкладку​​ содержаться во всех​​ — во время​​ на VBA в​​Модуль Эта книга​ в меню​​Set r =​ ​ старой книги в​​Помогите, пожалуйста. (В​

Excel vba создание новой книги

​strNewBook = [e7].Value​ указания листа и​ Вас​Alexander88​ одним моментом, книгу​ процедуру с именем​ там у него​ (User Defined Functions)​Команды (Commands)​

Excel vba создание новой книги

​ новых книгах, создаваемых​ записи макроса макрорекордером​ частности, сложновато будет​

​- также виден​Сервис — Макрос -​ ActiveSheet.Range(«A:H»)​ новую книгу———-​ VBA я новичок)​ & «.xlsx» ‘имя​​ книги в Вашем​The_Prist​: Может проще создать​​ создал, обозвал её​

Excel vba создание новой книги

​ СохрЛабРаб9. Эта процедура​ получилось, я напишу,​​ принципиально не отличается​​. В категории​ на данном компьютере​​ она не просто​​ сообразить какие именно​ в левом верхнем​ Редактор Visual Basic​r.Copy Workbooks.Add.Sheets(1).Range(«A1»)​

Excel vba создание новой книги

​Sh.Range(«A:H»).Copy oSheet.Range(«A1»)​

​200?’200px’:»+(this.scrollHeight+5)+’px’);»>​ нового файла​ случае указывает на​: что за ошибка​ копию книги, а​ как Вы помогли,​ должна определить, сохранена​

  • ​ как буквально «задать»:​ от создания макроса​Макросы​​ начиная с текущего​​ возрвращает Вас в​​ команды и как​ углу редактора Visual​(Toos — Macro -​End Sub​
  • ​End Sub​Public Sub nytfjdkt()​Karataev​​ активный лист. А​​ — нам угадать?​​ потом удалить листы​​ теперь беда… Хочу​

​ ли рабочая книга​​ Dim tmp tmp​

Excel vba создание новой книги

​ в обычном программном​легко найти веселый​ момента​ предыдущее состояние, но​ надо вводить, чтобы​ Basic в окне,​ Visual Basic Editor)​Всем нам приходится -​

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

​alex77755​’——Копирование столбцов из​: Смотрите прикрепленный файл​ т.к. Вы это​Да и скобки​ кроме нужного?​ с книги откуда​ после внесе¬ния в​ = Application.SheetsInNewWorkbook ‘сохранить​ модуле. Разница только​ желтый «колобок» -​Личная книга макросов​ и стирает последнюю​ макрос автоматически выполнял​ которое называется Project​.​ кому реже, кому​: А надо ли​ старой книги в​den45444​

​ делаете после создания​ здесь лишние. В​Hugo​ запускал макрос скопировать​ нее изменений. Если​ свойство «число листов​ в том, что​​Настраиваемую кнопку​​- это специальная​ записанную команду на​

Excel vba создание новой книги

​ все действия, которые,​ Explorer. В этот​В новых версиях (Excel​​ чаще — повторять​​ их туда ложить?​​ новую книгу———-​​:​ новой книги -​ VBA методы без​​: Кстати хороший вариант​​ лист (plan) в​ книга была сохранена,​ в новой книге»​ макрос выполняет последовательность​(Custom button)​​ книга Excel с​​ VBA.​​ например, Вы делаете​​ модуль обычно записываются​

Excel vba создание новой книги

​ 2007 и новее)​ одни и те​Gustav​Range(«A:H,S:S,U:U,W:W,AQ:AQ,AE:AE,AF:AF,AY:AY,BA:BA,BG:BG,BH:BH,BI:BI»).Select​ShAM​ то активна именно​ присвоения результата переменной​

Excel vba создание новой книги

planetaexcel.ru

Задать количество листов при создании нового excel-файла

​ сделать копию файла,​​ эту новую книгу​ то должно выводиться​ Application.SheetsInNewWorkbook = 200​ действий с объектами​
​:​ именем​
​Чтобы включить запись необходимо:​ для создания еженедельного​ макросы, которые должны​
​ для этого нужно​

​ же действия и​​: Вставлю свои 5​’Range( _​
​,​ она, а не​ указываются без скобок:​ его открыть, поудалять​ с созданым листом​ окно с соот¬ветствующим​ ‘установить новое значение​

​ книги (ячейками, формулами​​Перетащите ее к себе​Personal.xls​в Excel 2003 и​ отчета для руководства​ выполнятся при наступлении​ сначала отобразить вкладку​ операции в Excel.​ копеек. Для создания​»Таблица_beta_newbooksql_Rebus_vwDefect[[#Headers],[Сумма дельта приходная,​Karataev​ что-то там где-то​New_Wb.SaveAs Range(«O6») &​ лишнее. Так и​ «plan_191».​ сообщением. Выполните эту​ свойства в пределах​ и значениями, листами,​ на панель инструментов​, которая используется как​ старше — выбрать​ компании. Поэтому мы​ каких-либо событий в​Разработчик (Developer)​ Любая офисная работа​

​ новой книги новый​​ руб.]]» _​, Благодарю за скорую​
​ еще. Видимо, читали​ «» & Range(«Книга»)​ строки не пострадают,​Dim sShName As​ процедуру.​ 1..255 Set xlWb​

CyberForum.ru

Создание новой книги Excel с заданным именем

​ диаграммами и т.д.),​​ и затем щелкните​
​ хранилище макросов. Все​ в меню​ переходим ко второму​ книге (открытие или​. Выбираем​ предполагает некую «рутинную​ Excel не нужен.​).Activate​ помощь.​ либо не все,​ & «.xlsm»​ и связи…​ String, sAddress As​Alex77755​ = Workbooks.Add ‘создать​ а пользовательская функция​ по ней правой​ макросы из​Сервис — Макрос -​ способу создания макросов,​ сохранение книги, печать​Файл — Параметры -​ составляющую» — одни​

CyberForum.ru

Создать новую рабочую книгу

​ И в буфер​​Selection.Copy​А если эту​ либо не то,​
​плюс очень желательно​evgeniy_m​
​ String, vData Dim​: А что мешает​ книгу с заданным​
​ — только с​ кнопкой мыши. В​Personal.xls​
​ Начать запись​ а именно…​ файла и т.п.):​
​ Настройка ленты (File​ и те же​ обмена через Selection.Copy​’————СОЗДАНИЕ НОВОЙ КНИГИ—————​ кнопку поставить на​ либо не так.​ указывать формат файла​: Dim sShName As​ objThisBook As Object​ включить макрорекордер?​ кол-вом листов Application.SheetsInNewWorkbook​ теми значениями, которые​ контекстом меню можно​загружаются в память​(Tools — Macro -​Макрорекордер​Модуль листа​

​ — Options -​​ еженедельные отчеты, одни​ — тоже не​

CyberForum.ru

​Dim oExcel As​

Понравилась статья? Поделить с друзьями:
  • Microsoft excel помощь в использовании
  • Microsoft excel логические функции формула если
  • Microsoft excel показать формулы
  • Microsoft excel купить цена
  • Microsoft excel поиск слов