Время на прочтение
7 мин
Количество просмотров 312K
Приветствую всех.
В этом посте я расскажу, что такое VBA и как с ним работать в Microsoft Excel 2007/2010 (для более старых версий изменяется лишь интерфейс — код, скорее всего, будет таким же) для автоматизации различной рутины.
VBA (Visual Basic for Applications) — это упрощенная версия Visual Basic, встроенная в множество продуктов линейки Microsoft Office. Она позволяет писать программы прямо в файле конкретного документа. Вам не требуется устанавливать различные IDE — всё, включая отладчик, уже есть в Excel.
Еще при помощи Visual Studio Tools for Office можно писать макросы на C# и также встраивать их. Спасибо, FireStorm.
Сразу скажу — писать на других языках (C++/Delphi/PHP) также возможно, но требуется научится читать, изменять и писать файлы офиса — встраивать в документы не получится. А интерфейсы Microsoft работают через COM. Чтобы вы поняли весь ужас, вот Hello World с использованием COM.
Поэтому, увы, будем учить Visual Basic.
Чуть-чуть подготовки и постановка задачи
Итак, поехали. Открываем Excel.
Для начала давайте добавим в Ribbon панель «Разработчик». В ней находятся кнопки, текстовые поля и пр. элементы для конструирования форм.
Появилась вкладка.
Теперь давайте подумаем, на каком примере мы будем изучать VBA. Недавно мне потребовалось красиво оформить прайс-лист, выглядевший, как таблица. Идём в гугл, набираем «прайс-лист» и качаем любой, который оформлен примерно так (не сочтите за рекламу, пожалуйста):
То есть требуется, чтобы было как минимум две группы, по которым можно объединить товары (в нашем случае это будут Тип и Производитель — в таком порядке). Для того, чтобы предложенный мною алгоритм работал корректно, отсортируйте товары так, чтобы товары из одной группы стояли подряд (сначала по Типу, потом по Производителю).
Результат, которого хотим добиться, выглядит примерно так:
Разумеется, если смотреть прайс только на компьютере, то можно добавить фильтры и будет гораздо удобнее искать нужный товар. Однако мы хотим научится кодить и задача вполне подходящая, не так ли?
Кодим
Для начала требуется создать кнопку, при нажатии на которую будет вызываться наша програма. Кнопки находятся в панели «Разработчик» и появляются по кнопке «Вставить». Вам нужен компонент формы «Кнопка». Нажали, поставили на любое место в листе. Далее, если не появилось окно назначения макроса, надо нажать правой кнопкой и выбрать пункт «Назначить макрос». Назовём его FormatPrice. Важно, чтобы перед именем макроса ничего не было — иначе он создастся в отдельном модуле, а не в пространстве имен книги. В этому случае вам будет недоступно быстрое обращение к выделенному листу. Нажимаем кнопку «Новый».
И вот мы в среде разработки VB. Также её можно вызвать из контекстного меню командой «Исходный текст»/«View code».
Перед вами окно с заглушкой процедуры. Можете его развернуть. Код должен выглядеть примерно так:
Sub FormatPrice()End Sub
Напишем Hello World:
Sub FormatPrice()
MsgBox "Hello World!"
End Sub
И запустим либо щелкнув по кнопке (предварительно сняв с неё выделение), либо клавишей F5 прямо из редактора.
Тут, пожалуй, следует отвлечься на небольшой ликбез по поводу синтаксиса VB. Кто его знает — может смело пропустить этот раздел до конца. Основное отличие Visual Basic от Pascal/C/Java в том, что команды разделяются не ;, а переносом строки или двоеточием (:), если очень хочется написать несколько команд в одну строку. Чтобы понять основные правила синтаксиса, приведу абстрактный код.
Примеры синтаксиса
' Процедура. Ничего не возвращает
' Перегрузка в VBA отсутствует
Sub foo(a As String, b As String)
' Exit Sub ' Это значит "выйти из процедуры"
MsgBox a + ";" + b
End Sub' Функция. Вовращает Integer
Function LengthSqr(x As Integer, y As Integer) As Integer
' Exit Function
LengthSqr = x * x + y * y
End FunctionSub FormatPrice()
Dim s1 As String, s2 As String
s1 = "str1"
s2 = "str2"
If s1 <> s2 Then
foo "123", "456" ' Скобки при вызове процедур запрещены
End IfDim res As sTRING ' Регистр в VB не важен. Впрочем, редактор Вас поправит
Dim i As Integer
' Цикл всегда состоит из нескольких строк
For i = 1 To 10
res = res + CStr(i) ' Конвертация чего угодно в String
If i = 5 Then Exit For
Next iDim x As Double
x = Val("1.234") ' Парсинг чисел
x = x + 10
MsgBox xOn Error Resume Next ' Обработка ошибок - игнорировать все ошибки
x = 5 / 0
MsgBox xOn Error GoTo Err ' При ошибке перейти к метке Err
x = 5 / 0
MsgBox "OK!"
GoTo ne
Err:
MsgBox
"Err!"
ne:
On Error GoTo 0 ' Отключаем обработку ошибок
' Циклы бывает, какие захотите
Do While True
Exit DoLoop 'While True
Do 'Until False
Exit Do
Loop Until False
' А вот при вызове функций, от которых хотим получить значение, скобки нужны.
' Val также умеет возвращать Integer
Select Case LengthSqr(Len("abc"), Val("4"))
Case 24
MsgBox "0"
Case 25
MsgBox "1"
Case 26
MsgBox "2"
End Select' Двухмерный массив.
' Можно также менять размеры командой ReDim (Preserve) - см. google
Dim arr(1 to 10, 5 to 6) As Integer
arr(1, 6) = 8Dim coll As New Collection
Dim coll2 As Collection
coll.Add "item", "key"
Set coll2 = coll ' Все присваивания объектов должны производится командой Set
MsgBox coll2("key")
Set coll2 = New Collection
MsgBox coll2.Count
End Sub
Грабли-1. При копировании кода из IDE (в английском Excel) есь текст конвертируется в 1252 Latin-1. Поэтому, если хотите сохранить русские комментарии — надо сохранить крокозябры как Latin-1, а потом открыть в 1251.
Грабли-2. Т.к. VB позволяет использовать необъявленные переменные, я всегда в начале кода (перед всеми процедурами) ставлю строчку Option Explicit. Эта директива запрещает интерпретатору заводить переменные самостоятельно.
Грабли-3. Глобальные переменные можно объявлять только до первой функции/процедуры. Локальные — в любом месте процедуры/функции.
Еще немного дополнительных функций, которые могут пригодится: InPos, Mid, Trim, LBound, UBound. Также ответы на все вопросы по поводу работы функций/их параметров можно получить в MSDN.
Надеюсь, что этого Вам хватит, чтобы не пугаться кода и самостоятельно написать какое-нибудь домашнее задание по информатике. По ходу поста я буду ненавязчиво знакомить Вас с новыми конструкциями.
Кодим много и под Excel
В этой части мы уже начнём кодить нечто, что умеет работать с нашими листами в Excel. Для начала создадим отдельный лист с именем result (лист с данными назовём data). Теперь, наверное, нужно этот лист очистить от того, что на нём есть. Также мы «выделим» лист с данными, чтобы каждый раз не писать длинное обращение к массиву с листами.
Sub FormatPrice()
Sheets("result").Cells.Clear
Sheets("data").Activate
End Sub
Работа с диапазонами ячеек
Вся работа в Excel VBA производится с диапазонами ячеек. Они создаются функцией Range и возвращают объект типа Range. У него есть всё необходимое для работы с данными и/или оформлением. Кстати сказать, свойство Cells листа — это тоже Range.
Примеры работы с Range
Sheets("result").Activate
Dim r As Range
Set r = Range("A1")
r.Value = "123"
Set r = Range("A3,A5")
r.Font.Color = vbRed
r.Value = "456"
Set r = Range("A6:A7")
r.Value = "=A1+A3"
Теперь давайте поймем алгоритм работы нашего кода. Итак, у каждой строчки листа data, начиная со второй, есть некоторые данные, которые нас не интересуют (ID, название и цена) и есть две вложенные группы, к которым она принадлежит (тип и производитель). Более того, эти строки отсортированы. Пока мы забудем про пропуски перед началом новой группы — так будет проще. Я предлагаю такой алгоритм:
- Считали группы из очередной строки.
- Пробегаемся по всем группам в порядке приоритета (вначале более крупные)
- Если текущая группа не совпадает, вызываем процедуру AddGroup(i, name), где i — номер группы (от номера текущей до максимума), name — её имя. Несколько вызовов необходимы, чтобы создать не только наш заголовок, но и всё более мелкие.
- После отрисовки всех необходимых заголовков делаем еще одну строку и заполняем её данными.
Для упрощения работы рекомендую определить следующие функции-сокращения:
Function GetCol(Col As Integer) As String
GetCol = Chr(Asc("A") + Col)
End FunctionFunction GetCellS(Sheet As String, Col As Integer, Row As Integer) As Range
Set GetCellS = Sheets(Sheet).Range(GetCol(Col) + CStr(Row))
End FunctionFunction GetCell(Col As Integer, Row As Integer) As Range
Set GetCell = Range(GetCol(Col) + CStr(Row))
End Function
Далее определим глобальную переменную «текущая строчка»: Dim CurRow As Integer. В начале процедуры её следует сделать равной единице. Еще нам потребуется переменная-«текущая строка в data», массив с именами групп текущей предыдущей строк. Потом можно написать цикл «пока первая ячейка в строке непуста».
Глобальные переменные
Option Explicit ' про эту строчку я уже рассказывал
Dim CurRow As Integer
Const GroupsCount As Integer = 2
Const DataCount As Integer = 3
FormatPrice
Sub FormatPrice()
Dim I As Integer ' строка в data
CurRow = 1
Dim Groups(1 To GroupsCount) As String
Dim PrGroups(1 To GroupsCount) As String
Sheets(
"data").Activate
I = 2
Do While True
If GetCell(0, I).Value = "" Then Exit Do
' ...
I = I + 1
Loop
End Sub
Теперь надо заполнить массив Groups:
На месте многоточия
Dim I2 As Integer
For I2 = 1 To GroupsCount
Groups(I2) = GetCell(I2, I)
Next I2
' ...
For I2 = 1 To GroupsCount ' VB не умеет копировать массивы
PrGroups(I2) = Groups(I2)
Next I2
I = I + 1
И создать заголовки:
На месте многоточия в предыдущем куске
For I2 = 1 To GroupsCount
If Groups(I2) <> PrGroups(I2) Then
Dim I3 As Integer
For I3 = I2 To GroupsCount
AddHeader I3, Groups(I3)
Next I3
Exit For
End If
Next I2
Не забудем про процедуру AddHeader:
Перед FormatPrice
Sub AddHeader(Ty As Integer, Name As String)
GetCellS("result", 1, CurRow).Value = Name
CurRow = CurRow + 1
End Sub
Теперь надо перенести всякую информацию в result
For I2 = 0 To DataCount - 1
GetCellS("result", I2, CurRow).Value = GetCell(I2, I)
Next I2
Подогнать столбцы по ширине и выбрать лист result для показа результата
После цикла в конце FormatPrice
Sheets("Result").Activate
Columns.AutoFit
Всё. Можно любоваться первой версией.
Некрасиво, но похоже. Давайте разбираться с форматированием. Сначала изменим процедуру AddHeader:
Sub AddHeader(Ty As Integer, Name As String)
Sheets("result").Range("A" + CStr(CurRow) + ":C" + CStr(CurRow)).Merge
' Чтобы не заводить переменную и не писать каждый раз длинный вызов
' можно воспользоваться блоком With
With GetCellS("result", 0, CurRow)
.Value = Name
.Font.Italic = True
.Font.Name = "Cambria"
Select Case Ty
Case 1 ' Тип
.Font.Bold = True
.Font.Size = 16
Case 2 ' Производитель
.Font.Size = 12
End Select
.HorizontalAlignment = xlCenter
End With
CurRow = CurRow + 1
End Sub
Уже лучше:
Осталось только сделать границы. Тут уже нам требуется работать со всеми объединёнными ячейками, иначе бордюр будет только у одной:
Поэтому чуть-чуть меняем код с добавлением стиля границ:
Sub AddHeader(Ty As Integer, Name As String)
With Sheets("result").Range("A" + CStr(CurRow) + ":C" + CStr(CurRow))
.Merge
.Value = Name
.Font.Italic = True
.Font.Name = "Cambria"
.HorizontalAlignment = xlCenterSelect Case Ty
Case 1 ' Тип
.Font.Bold = True
.Font.Size = 16
.Borders(xlTop).Weight = xlThick
Case 2 ' Производитель
.Font.Size = 12
.Borders(xlTop).Weight = xlMedium
End Select
.Borders(xlBottom).Weight = xlMedium ' По убыванию: xlThick, xlMedium, xlThin, xlHairline
End With
CurRow = CurRow + 1
End Sub
Осталось лишь добится пропусков перед началом новой группы. Это легко:
В начале FormatPrice
Dim I As Integer ' строка в data
CurRow = 0 ' чтобы не было пропуска в самом начале
Dim Groups(1 To GroupsCount) As String
В цикле расстановки заголовков
If Groups(I2) <> PrGroups(I2) Then
CurRow = CurRow + 1
Dim I3 As Integer
В точности то, что и хотели.
Надеюсь, что эта статья помогла вам немного освоится с программированием для Excel на VBA. Домашнее задание — добавить заголовки «ID, Название, Цена» в результат. Подсказка: CurRow = 0 CurRow = 1.
Файл можно скачать тут (min.us) или тут (Dropbox). Не забудьте разрешить исполнение макросов. Если кто-нибудь подскажет человеческих файлохостинг, залью туда.
Спасибо за внимание.
Буду рад конструктивной критике в комментариях.
UPD: Перезалил пример на Dropbox и min.us.
UPD2: На самом деле, при вызове процедуры с одним параметром скобки можно поставить. Либо использовать конструкцию Call Foo(«bar», 1, 2, 3) — тут скобки нужны постоянно.
Первое знакомство с редактором VBA Excel, создание процедур (подпрограмм) и написание простейшего кода, работающего с переменными и ячейками рабочего листа.
Начинаем программировать с нуля
Часть 1. Первая программа
[Часть 1] [Часть 2] [Часть 3] [Часть 4]
Эта статья предназначена для тех, кто желает научиться программировать в VBA Excel с нуля. Вы увидите, как это работает, и убедитесь, что не все так сложно, как кажется с первого взгляда. Свою первую программу вы напишите за 7 простых шагов.
- Создайте новую книгу Excel и сохраните ее как книгу с поддержкой макросов с расширением .xlsm. В старых версиях Excel по 2003 год – как обычную книгу с расширением .xls.
- Нажмите сочетание клавиш «Левая_клавиша_Alt+F11», которое откроет редактор VBA. С правой клавишей Alt такой фокус не пройдет. Также, в редактор VBA можно перейти по ссылке «Visual Basic» из панели инструментов «Разработчик» на ленте быстрого доступа. Если вкладки «Разработчик» на ленте нет, ее следует добавить в настройках параметров Excel.
В левой части редактора VBA расположен проводник проекта, в котором отображены все открытые книги Excel. Верхней строки, как на изображении, у вас скорее всего не будет, так как это – личная книга макросов. Справа расположен модуль, в который записываются процедуры (подпрограммы) с кодом VBA. На изображении открыт модуль листа, мы же далее создадим стандартный программный модуль.
- Нажмите кнопку «Module» во вкладке «Insert» главного меню. То же подменю откроется при нажатии на вторую кнопку после значка Excel на панели инструментов.
После нажатия кнопки «Module» вы увидите ссылку на него, появившуюся в проводнике слева.
Первая программа на VBA Excel
Добавляем на стандартный модуль шаблон процедуры – строки ее начала и завершения, между которыми мы и будем писать свою первую программу (процедуру, подпрограмму).
- Откройте стандартный модуль двойным кликом по его ссылке в проводнике. Поместите в него курсор и нажмите кнопку «Procedure…» во вкладке «Insert» главного меню. Та же ссылка будет доступна при нажатии на вторую кнопку после значка Excel на панели инструментов.
В результате откроется окно добавления шаблона процедуры (Sub).
- Наберите в поле «Name» имя процедуры: «Primer1», или скопируйте его отсюда и вставьте в поле «Name». Нажмите кнопку «OK», чтобы добавить в модуль первую и последнюю строки процедуры.
Имя процедуры может быть написано как на латинице, так и на кириллице, может содержать цифры и знак подчеркивания. Оно обязательно должно начинаться с буквы и не содержать пробелы, вместо которых следует использовать знак подчеркивания.
- Вставьте внутрь шаблона процедуры следующую строку:
MsgBox "Привет"
.
Функция MsgBox выводит информационное сообщение с указанным текстом. В нашем примере – это «Привет».
- Проверьте, что курсор находится внутри процедуры, и запустите ее, нажав клавишу «F5». А также, запустить процедуру на выполнение можно, нажав на треугольник (на изображении под пунктом меню «Debug») или на кнопку «Run Sub/UserForm» во вкладке «Run» главного меню редактора VBA Excel.
Если вы увидели такое сообщение, как на изображении, то, поздравляю – вы написали свою первую программу!
Работа с переменными
Чтобы использовать в процедуре переменные, их необходимо объявить с помощью ключевого слова «Dim». Если при объявлении переменных не указать типы данных, они смогут принимать любые доступные в VBA Excel значения. Комментарии в тексте процедур начинаются со знака «’» (апостроф).
Пример 2
Присвоение переменным числовых значений:
Public Sub Primer2() ‘Объявляем переменные x, y, z Dim x, y, z ‘Присваиваем значение переменной x x = 25 ‘Присваиваем значение переменной y y = 35 ‘Присваиваем переменной z сумму ‘значений переменных x и y z = x + y ‘Выводим информационное сообщение ‘со значением переменной z MsgBox z End Sub |
Пример 3
Присвоение переменным строковых значений:
Public Sub Primer3() ‘Объявляем переменные x, y, z Dim x, y, z ‘Присваиваем строку переменной x x = «Добрый» ‘Присваиваем строку переменной y y = «день!» ‘Присваиваем переменной z строку, ‘состоящую из строк x и y ‘с пробелом между ними z = x & » « & y ‘Выводим информационное сообщение ‘со значением переменной z MsgBox z End Sub |
Скопируйте примеры процедур в стандартный модуль и запустите их на выполнение.
Изменение содержимого ячеек
Для обозначения диапазонов, в том числе и отдельных ячеек, в VBA Excel имеется ключевое слово «Range». Ячейке A1 на рабочем листе будет соответствовать выражение Range("A1")
в коде VBA Excel.
Пример 4
Public Sub Primer4() ‘Объявляем переменную x Dim x ‘Присваиваем значение переменной x x = 125.61 ‘Присваиваем ячейке A1 ‘значение переменной x Range(«A1») = x ‘Присваиваем значение ячейке B1 Range(«B1») = 356.24 ‘Записываем в ячейку C1 ‘сумму ячеек A1 и B1 Range(«C1») = Range(«A1») + Range(«B1») End Sub |
Скопируйте процедуру этого примера в стандартный модуль и запустите на выполнение. Перейдите на активный рабочий лист Excel, чтобы увидеть результат.
- Введение в программирование в Excel
Программирование в Excel (Содержание)
- Введение в программирование в Excel
- Как программировать в Excel?
Введение в программирование в Excel
Вы когда-нибудь уставали выполнять задачи в Excel, которые, по вашему мнению, могут быть автоматизированы и сэкономить ваше время? В большинстве случаев вы сталкивались с такими задачами. Однако для того, чтобы автоматизировать любую задачу, вам прежде всего необходимо иметь навыки программирования для этого конкретного языка. В Excel вы можете выполнять программирование с помощью Visual Basic for Application (VBA), который является собственным языком программирования Excel, который может помочь вам автоматизировать задачи. В этой статье мы увидим, как мы можем заниматься программированием в Excel VBA. VBA можно использовать для написания программы, которая может автоматизировать задачу для вас. Часть строк, которую мы пишем в VBA, называется Macro, которая написана таким образом, что они инструктируют систему Excel о том, что нужно сделать.
Как программировать в Excel?
Давайте разберемся, как программировать в Excel с несколькими иллюстрациями.
Включение вкладки разработчика
Первое, что приходит, это включение вкладки разработчика, которая помогает вам записывать и хранить макрос (код VBA). Давайте посмотрим, как мы можем включить это.
- Перейдите в меню « Файл» в вашем файле Excel и нажмите на него.
- В меню «Файл» нажмите « Параметры», и откроется новое окно со всеми доступными параметрами Excel.
- В появившемся новом окне с именем « Параметры Excel» перейдите на вкладку « Настройка ленты ». Вы можете увидеть все параметры настройки, которые вы можете использовать для ленты Excel, которая отображается в верхней части файла Excel.
- Включите параметр « Разработчик» в раскрывающемся списке «Основные вкладки» в разделе « Настройка ленты: ». Вы можете отметить (отметить) вкладку « Разработчик », чтобы включить ее. Нажмите кнопку ОК, расположенную в правом нижнем углу вкладки Параметры Excel, и все.
- Вы успешно включили опцию Разработчик в вашем Excel. Если вы проверите ленту Excel в своем файле сейчас, вы сможете увидеть новую вкладку, добавленную туда с именем Developer.
Это первый шаг, который вы должны выполнить, прежде чем начать писать макросы в Excel. Потому что вкладка «Разработчик» — это то, что нужно для записи и запуска макроса. Эта вкладка по умолчанию не включена, и поэтому мы сначала попробовали включить ее здесь.
Запись макроса
- Откройте файл Excel. Перейдите на вкладку « Разработчик », которую вы только что включили, а затем нажмите кнопку « Записать макрос», классифицируйте ее и можно увидеть в разделе « Код ».
- Как только вы нажмете кнопку «Запись макроса», вы увидите всплывающее окно, в этом окне вам нужно будет присвоить имя макросу, вы также можете назначить горячую клавишу для запуска этого макроса. Можно добавить описание, если таковое имеется для этого макроса, который вы создаете. Как только вы закончите со всем этим, вы можете нажать на кнопку ОК, расположенную в правой нижней части окна. Смотрите скриншот ниже для вашей справки.
Как только вы нажмете OK, система начнет запись макроса, и все выполняемые вами задачи будут записаны и преобразованы в программу Excel в бэкэнде.
- Попробуйте ввести предложение «Это мой первый код VBA, и я очень счастлив!» В ячейке A1 на листе Excel и нажмите клавишу «Ввод». Эти шаги будут записаны в серверной части макроса.
- В разделе «Код» вы могли заметить, что кнопка «Запись макроса» была изменена на «Остановить запись». Это как Play and Stop. Макрос записи работает как кнопка воспроизведения, а остановка записи работает как кнопка остановки. Нажмите кнопку «Остановить запись», чтобы остановить запись.
Волшебство, стоящее за всем этим, заключается в том, что Excel записал мои шаги здесь и преобразовал их в фрагменты кода, чтобы эта задача могла быть автоматизирована. Это означает, что каждый шаг, выбрав ячейку A1, введите текст «Это мой первый код VBA, и я счастлив!», Нажав Enter, чтобы перейти к следующей ячейке. Все эти шаги преобразуются в код VBA. Давайте проверим код сейчас.
- Чтобы перейти к редактору Visual Basic, вы можете щелкнуть параметр Visual Basic в категории « Код » на вкладке « Разработчик » или использовать Alt + F11 в качестве ярлыка для того же.
- Перейдите к разделу « Модули » в VBAProject и нажмите кнопку «плюс» под ним, чтобы увидеть список активных модулей в VBA.
- Внутри папки Modules вы можете увидеть Module1, как только вы нажмете на знак плюс. Вы можете дважды щелкнуть на модуле 1, где записан ваш код для задачи, которую мы выполняли на предыдущих шагах (шаги 3 и 4). Сохраните этот код, и вы сможете запускать его каждый раз, чтобы получить один и тот же вывод. Смотрите скриншот ниже:
Вывод
- Мы можем записать макрос в Excel, чтобы автоматизировать повседневные небольшие задачи, которые проще для системы манипулировать программно.
- Самое классное в этом то, что вам не нужно копать голову глубоко для логики каждого выполняемого вами шага. Excel VBA сделает это за вас.
- Для некоторых сложных задач, таких как та, которая включает в себя циклические и условные операторы, вам нужно написать код вручную в VBA.
Что нужно помнить о программировании в Excel
- Вкладка «Разработчики» по умолчанию не включена и отображается в ленте Excel. Вам нужно включить его через параметры Excel.
- Запись макроса работает над простыми задачами, которые повторяются, и вам нужно автоматизировать их. Тем не менее, для сложных задач, которые включают в себя циклы или условные входы и выходы, их все равно необходимо кодировать вручную в VBA.
- Вам необходимо сохранить файл в формате Excel-Macro Enable, чтобы иметь возможность читать и снова запускать код в Excel.
Рекомендуемые статьи
Это руководство по программированию в Excel. Здесь мы обсуждаем, как программировать в Excel вместе с практическими примерами и загружаемым шаблоном Excel. Вы также можете просмотреть наши другие предлагаемые статьи —
- Компоненты ленты в Excel
- Введение в формулу TRIM в Excel
- Шаблон управления проектами в Excel
- Как использовать COUNTIFS в Excel?
#Руководства
- 23 май 2022
-
0
Как с помощью макросов автоматизировать рутинные задачи в Excel? Какие команды они выполняют? Как создать макрос новичку? Разбираемся на примере.
Иллюстрация: Meery Mary для Skillbox Media
Рассказывает просто о сложных вещах из мира бизнеса и управления. До редактуры — пять лет в банке и три — в оценке имущества. Разбирается в Excel, финансах и корпоративной жизни.
Макрос (или макрокоманда) в Excel — алгоритм действий в программе, который объединён в одну команду. С помощью макроса можно выполнить несколько шагов в Excel, нажав на одну кнопку в меню или на сочетание клавиш.
Обычно макросы используют для автоматизации рутинной работы — вместо того чтобы выполнять десяток повторяющихся действий, пользователь записывает одну команду и затем запускает её, когда нужно совершить эти действия снова.
Например, если нужно добавить название компании в несколько десятков документов и отформатировать его вид под корпоративный дизайн, можно делать это в каждом документе отдельно, а можно записать ход действий при создании первого документа в макрос — и затем применить его ко всем остальным. Второй вариант будет гораздо проще и быстрее.
В статье разберёмся:
- как работают макросы и как с их помощью избавиться от рутины в Excel;
- какие способы создания макросов существуют и как подготовиться к их записи;
- как записать и запустить макрос начинающим пользователям — на примере со скриншотами.
Общий принцип работы макросов такой:
- Пользователь записывает последовательность действий, которые нужно выполнить в Excel, — о том, как это сделать, поговорим ниже.
- Excel обрабатывает эти действия и создаёт для них одну общую команду. Получается макрос.
- Пользователь запускает этот макрос, когда ему нужно выполнить эту же последовательность действий ещё раз. При записи макроса можно задать комбинацию клавиш или создать новую кнопку на главной панели Excel — если нажать на них, макрос запустится автоматически.
Макросы могут выполнять любые действия, которые в них запишет пользователь. Вот некоторые команды, которые они умеют делать в Excel:
- Автоматизировать повторяющиеся процедуры.
Например, если пользователю нужно каждый месяц собирать отчёты из нескольких файлов в один, а порядок действий каждый раз один и тот же, можно записать макрос и запускать его ежемесячно.
- Объединять работу нескольких программ Microsoft Office.
Например, с помощью одного макроса можно создать таблицу в Excel, вставить и сохранить её в документе Word и затем отправить в письме по Outlook.
- Искать ячейки с данными и переносить их в другие файлы.
Этот макрос пригодится, когда нужно найти информацию в нескольких объёмных документах. Макрос самостоятельно отыщет её и принесёт в заданный файл за несколько секунд.
- Форматировать таблицы и заполнять их текстом.
Например, если нужно привести несколько таблиц к одному виду и дополнить их новыми данными, можно записать макрос при форматировании первой таблицы и потом применить его ко всем остальным.
- Создавать шаблоны для ввода данных.
Команда подойдёт, когда, например, нужно создать анкету для сбора данных от сотрудников. С помощью макроса можно сформировать такой шаблон и разослать его по корпоративной почте.
- Создавать новые функции Excel.
Если пользователю понадобятся дополнительные функции, которых ещё нет в Excel, он сможет записать их самостоятельно. Все базовые функции Excel — это тоже макросы.
Все перечисленные команды, а также любые другие команды пользователя можно комбинировать друг с другом и на их основе создавать макросы под свои потребности.
В Excel и других программах Microsoft Office макросы создаются в виде кода на языке программирования VBA (Visual Basic for Applications). Этот язык разработан в Microsoft специально для программ компании — он представляет собой упрощённую версию языка Visual Basic. Но это не значит, что для записи макроса нужно уметь кодить.
Есть два способа создания макроса в Excel:
- Написать макрос вручную.
Это способ для продвинутых пользователей. Предполагается, что они откроют окно Visual Basic в Еxcel и самостоятельно напишут последовательность действий для макроса в виде кода.
- Записать макрос с помощью кнопки меню Excel.
Способ подойдёт новичкам. В этом варианте Excel запишет программный код вместо пользователя. Нужно нажать кнопку записи и выполнить все действия, которые планируется включить в макрос, и после этого остановить запись — Excel переведёт каждое действие и выдаст алгоритм на языке VBA.
Разберёмся на примере, как создать макрос с помощью второго способа.
Допустим, специальный сервис автосалона выгрузил отчёт по продажам за три месяца первого квартала в формате таблиц Excel. Эти таблицы содержат всю необходимую информацию, но при этом никак не отформатированы: колонки слиплись друг с другом и не видны полностью, шапка таблицы не выделена и сливается с другими строками, часть данных не отображается.
Скриншот: Skillbox Media
Пользоваться таким отчётом неудобно — нужно сделать его наглядным. Запишем макрос при форматировании таблицы с продажами за январь и затем применим его к двум другим таблицам.
Готовимся к записи макроса
Кнопки для работы с макросами в Excel находятся во вкладке «Разработчик». Эта вкладка по умолчанию скрыта, поэтому для начала разблокируем её.
В операционной системе Windows это делается так: переходим во вкладку «Файл» и выбираем пункты «Параметры» → «Настройка ленты». В открывшемся окне в разделе «Основные вкладки» находим пункт «Разработчик», отмечаем его галочкой и нажимаем кнопку «ОК» → в основном меню Excel появляется новая вкладка «Разработчик».
В операционной системе macOS это нужно делать по-другому. В самом верхнем меню нажимаем на вкладку «Excel» и выбираем пункт «Параметры…».
Скриншот: Skillbox Media
В появившемся окне нажимаем кнопку «Лента и панель».
Скриншот: Skillbox Media
Затем в правой панели «Настроить ленту» ищем пункт «Разработчик» и отмечаем его галочкой. Нажимаем «Сохранить».
Скриншот: Skillbox Media
Готово — вкладка «Разработчик» появилась на основной панели Excel.
Скриншот: Skillbox Media
Чтобы Excel смог сохранить и в дальнейшем использовать макрос, нужно пересохранить документ в формате, который поддерживает макросы. Это делается через команду «Сохранить как» на главной панели. В появившемся меню нужно выбрать формат «Книга Excel с поддержкой макросов».
Скриншот: Skillbox Media
Перед началом записи макроса важно знать об особенностях его работы:
- Макрос записывает все действия пользователя.
После старта записи макрос начнёт регистрировать все клики мышки и все нажатия клавиш. Поэтому перед записью последовательности лучше хорошо отработать её, чтобы не добавлять лишних действий и не удлинять код. Если требуется записать длинную последовательность задач — лучше разбить её на несколько коротких и записать несколько макросов.
- Работу макроса нельзя отменить.
Все действия, которые выполняет запущенный макрос, остаются в файле навсегда. Поэтому перед тем, как запускать макрос в первый раз, лучше создать копию всего файла. Если что-то пойдёт не так, можно будет просто закрыть его и переписать макрос в созданной копии.
- Макрос выполняет свой алгоритм только для записанного диапазона таблиц.
Если при записи макроса пользователь выбирал диапазон таблицы, то и при запуске макроса в другом месте он выполнит свой алгоритм только в рамках этого диапазона. Если добавить новую строку, макрос к ней применяться не будет. Поэтому при записи макроса можно сразу выбирать большее количество строк — как это сделать, показываем ниже.
Для начала записи макроса перейдём на вкладку «Разработчик» и нажмём кнопку «Записать макрос».
Скриншот: Skillbox Media
Появляется окно для заполнения параметров макроса. Нужно заполнить поля: «Имя макроса», «Сохранить в», «Сочетание клавиш», «Описание».
Скриншот: Skillbox Media
«Имя макроса» — здесь нужно придумать и ввести название для макроса. Лучше сделать его логически понятным, чтобы в дальнейшем можно было быстро его найти.
Первым символом в названии обязательно должна быть буква. Другие символы могут быть буквами или цифрами. Важно не использовать пробелы в названии — их можно заменить символом подчёркивания.
«Сохранить в» — здесь нужно выбрать книгу, в которую макрос сохранится после записи.
Если выбрать параметр «Эта книга», макрос будет доступен при работе только в этом файле Excel. Чтобы макрос был доступен всегда, нужно выбрать параметр «Личная книга макросов» — Excel создаст личную книгу макросов и сохранит новый макрос в неё.
«Сочетание клавиш» — здесь к уже выбранным двум клавишам (Ctrl + Shift в системе Windows и Option + Cmd в системе macOS) нужно добавить третью клавишу. Это должна быть строчная или прописная буква, которую ещё не используют в других быстрых командах компьютера или программы Excel.
В дальнейшем при нажатии этих трёх клавиш записанный макрос будет запускаться автоматически.
«Описание» — необязательное поле, но лучше его заполнять. Например, можно ввести туда последовательность действий, которые планируется записать в этом макросе. Так не придётся вспоминать, какие именно команды выполнит этот макрос, если нужно будет запустить его позже. Плюс будет проще ориентироваться среди других макросов.
В нашем случае с форматированием таблицы заполним поля записи макроса следующим образом и нажмём «ОК».
Скриншот: Skillbox Media
После этого начнётся запись макроса — в нижнем левом углу окна Excel появится значок записи.
Скриншот: Skillbox Media
Пока идёт запись, форматируем таблицу с продажами за январь: меняем ширину всех столбцов, данные во всех ячейках располагаем по центру, выделяем шапку таблицы цветом и жирным шрифтом, рисуем границы.
Важно: в нашем случае у таблиц продаж за январь, февраль и март одинаковое количество столбцов, но разное количество строк. Чтобы в случае со второй и третьей таблицей макрос сработал корректно, при форматировании выделим диапазон так, чтобы в него попали не только строки самой таблицы, но и строки ниже неё. Для этого нужно выделить столбцы в строке с их буквенным обозначением A–G, как на рисунке ниже.
Скриншот: Skillbox Media
Если выбрать диапазон только в рамках первой таблицы, то после запуска макроса в таблице с большим количеством строк она отформатируется только частично.
Скриншот: Skillbox Media
После всех манипуляций с оформлением таблица примет такой вид:
Скриншот: Skillbox Media
Проверяем, все ли действия с таблицей мы выполнили, и останавливаем запись макроса. Сделать это можно двумя способами:
- Нажать на кнопку записи в нижнем левом углу.
- Перейти во вкладку «Разработчик» и нажать кнопку «Остановить запись».
Скриншот: Skillbox Media
Готово — мы создали макрос для форматирования таблиц в границах столбцов A–G. Теперь его можно применить к другим таблицам.
Запускаем макрос
Перейдём в лист со второй таблицей «Февраль_2022». В первоначальном виде она такая же нечитаемая, как и первая таблица до форматирования.
Скриншот: Skillbox Media
Отформатируем её с помощью записанного макроса. Запустить макрос можно двумя способами:
- Нажать комбинацию клавиш, которую выбрали при заполнении параметров макроса — в нашем случае Option + Cmd + Ф.
- Перейти во вкладку «Разработчик» и нажать кнопку «Макросы».
Скриншот: Skillbox Media
Появляется окно — там выбираем макрос, который нужно запустить. В нашем случае он один — «Форматирование_таблицы». Под ним отображается описание того, какие действия он включает. Нажимаем «Выполнить».
Скриншот: Skillbox Media
Готово — вторая таблица с помощью макроса форматируется так же, как и первая.
Скриншот: Skillbox Media
То же самое можно сделать и на третьем листе для таблицы продаж за март. Более того, этот же макрос можно будет запустить и в следующем квартале, когда сервис автосалона выгрузит таблицы с новыми данными.
Научитесь: Excel + Google Таблицы с нуля до PRO
Узнать больше
VBA Excel: примеры программ. Макросы в Excel
Смотрите также хотите чего-то достичь, запускаться при запуске действия, совершаемые пользователями, данных. ОКРУГЛ, ОКРУГЛВВЕРХ и по одному или Excel с чистого выполнять финансовые, математические по порядку. Те, суммарной величины —и пр. 1)) 11, то пишем: значение аргумента функции конкретных примеров программСледующее понятие — свойства.Немногие знают, что первая
Что такое VBA
а не быть файла екселя и которые запускают выполнениеТаблицы: Таблицы нужны для ОКРУГЛВНИЗ. по нескольким критериям. листа, Вы можете
и статистические вычисления. кто имеет опыт (ItogF – ItogP).Изучение свойств этих функцийIf x>0 Then Cells(1,For i = 1 берут x1=0 и VBA Excel. Лучше Они являются необходимой версия популярного продукта всю жизнь топикстартером).
делать что-то. кода VBA. того, чтобы выполнятьПримеры: Отбрасываем десятичные знаки,Примеры: Подсчёт вхождений текста, создать рабочую книгуДиапазон: Диапазон в Excel в программировании наРезультаты опять же сразу и их применение 1).Value = 1 to 10 step x2=10. Кроме того, всего начать с характеристикой любого объекта. Microsoft Excel появилась С уважением, Сергей.Darkgod666Массив: Массив – это анализ имеющихся данных Ближайшее кратное, Четные Подсчёт логических значений,
Объекты, коллекции, свойства и методы
на базе шаблона. – это набор VBA, могут сразу записываются в соответствующие позволит значительно расширитьIf x=0 Then Cells(1, 1 Next. необходимо ввести константу самых элементарных кодов. Например, для Range в 1985 году.Serge: Нет. Это просто
группа переменных. В быстро и легко. и нечетные. Подсчёт пустых и Существует множество бесплатных из двух или же перейти к ячейки, поэтому нет сферу применения «Эксель». 1).Value = 0
Здесь step — шаг. — значение дляЗадача: написать программу, которая — это Value С тех пор: Выбирал такие чтоб работа с конкретной VBA Вы можете
Анализ «Что-если»: Анализ «Что-если»Ошибки в формулах: Эта непустых ячеек, Функция шаблонов, которые так более ячеек. В интересующим темам.
необходимости их присваиванияПопробуем перейти к решениюIf x В данном случае шага изменения аргумента будет копировать значение или Formula. он пережил несколько мне понятно было. программой. Работа с сослаться на определённую в Excel позволяет глава научит Вас СУММПРОИЗВ. и просятся, чтобы
этой главе ВыЧасть 1: Оформление кода переменным. более сложных задач.
Как начать
End Sub. он равен двум. и начальное значение содержимое одной ячейкиМетоды — это команды, модификаций и востребован
Сам чайник в медиаплеером является программированием?) переменную (элемент) массива, подставлять различные значения справляться с некоторыми
- Логические функции: Узнайте, как их использовали. найдёте обзор некоторыхЧасть 2: Типы данных,Перед запуском созданной программы,
- Например:
- Остается запустить макрос и По умолчанию отсутствие для счетчика.
- и затем записывать показывающие, что требуется
у миллионов пользователей
макросах, но эти
) Просто «программисты»
используя для этого
(сценарии) в формулы. распространёнными ошибками в пользоваться логическими функциямиПримеры: Календарь, Бюджет, Планировщик очень важных операций переменные и константы требуется сохранить рабочуюДан бумажный документ отчета
получить в «Эксель» этого слова вВсе примеры макросов VBA в другую. сделать. При написании по всему миру. книги читаются легко. пошли такие, что имя массива иПоиск Решения: В арсенале формулах Excel. Excel, такими как питания, Счет-фактура, Автоматизированный с диапазонами.
Макросы в Excel
Часть 3: Массивы книгу, например, под фактического уровня издержек нужное значение для цикле означает, что Excel создаются поДля этого: кода в VBA При этом многиеВика х** пишут с числовой индекс элемента. Excel есть инструмент,Примеры: ЕСЛИОШИБКА, ЕОШИБКА, Циклическая ЕСЛИ, И, ИЛИ. счет-фактура, Шаблоны поПримеры: Последовательность Фибоначчи, ПользовательскиеЧасть 4: Процедуры Function названием «Отчет1.xls». предприятия. Требуется:
Пример 1
аргумента. шаг единичный. той же процедуре,открывают вкладку «Вид»; их необходимо отделять
работают лишь с
- : Помогите найти и
- мягким знаком, для
- Function и Sub: В
- который называется «Поиск
ссылка, Зависимости формул,Примеры: Вложенные функции ЕСЛИ, умолчанию. списки, Примечания, Скрытие и SubКлавишу «Создать отчетную таблицу»разработать его шаблонную частьКак вы уже моглиПолученные результаты нужно сохранять
которая представлена выше.переходят на пиктограмму «Макросы»; от объекта точкой. малой толикой возможностей скачать самоучитель по них «пуск» нажать-уже Visual Basic for Решения». Он использует Ошибка плавающей запятой.
Игра «Бросить кости».
- Проверка данных: Используйте проверку строк и столбцов,
- Часть 5: Условные операторы требуется нажать всего
- посредством табличного процессора заметить, программировать в в ячейки с
В данном конкретномжмут на «Запись макроса»; Например, как будет этого табличного процессора
EXCEL «программирование»)) Applications функция (Function) различные методы анализаФормулы массива: Изучив этуСсылки на ячейки: Ссылка данных в Excel Пропускать пустые ячейки,Часть 6: Циклы 1 раз после «Эксель»; самом известном табличном
номером (i,1). Тогда случае код выглядит,заполняют открывшуюся форму. показано в дальнейшем, и даже неvikttur=Serge= может возвращать значение, вычислений для поиска главу, Вы будете на ячейку – и будьте уверены,
Транспонирование, Объединение иЧасть 7: Операторы и ввода заголовочной информации.составить программу VBA, которая процессоре Microsoft не при каждом запуске как:
Пример 2
Для простоты в поле очень часто при догадываются, как им
: Вика, Вы ссылки,: В некотором роде, в то время наилучших решений для понимать, что такое это очень важный что пользователи введут пересечение. встроенные функции Следует знать и
будет запрашивать исходные так уж сложно. цикла с увеличениемSub programm() «Имя макроса» оставляют программировании в «Эксель» могло бы облегчить показанные в теме, так как навыки
как процедура (Sub) задач оптимизации всех формулы массива в элемент Excel. Поймите в ячейку толькоФормулы и функции: ФормулаЧасть 8: Объектная модель
другие правила. В
данные для ее
Особенно, если научиться
i на величину
x1 = 1
«Макрос1», а в используют команду Cells(1,1).Select. жизнь умение программирования просмотрели? Или нужно те же. Вы
– не может. видов.
Excel. Одноячеечные формулы разницу между относительной, подходящее значение. – это выражение,
Excel частности, кнопка «Добавить заполнения, осуществлять необходимые применять функции VBA.
шага автоматически будетx2 = 10
поле «Сочетание клавиш» Она означает, что в Excel.
«разжевать и в
попробуйте в VBA
Объект Application: Главным вПакет анализа: Пакет анализа массива позволяют выполнять абсолютной и смешаннойПримеры: Отбросить недопустимые даты, которое вычисляет значениеЧасть 9: События в строку» должна нажиматься
расчеты и заполнять Всего в этом расти и номер
Пример 3
shag = 0.1 вставляют, например, hh необходимо выбрать ячейкуПрограммирование в Excel осуществляется рот положить»? (Visual Basic for иерархии объектов является
– это надстройка сразу серию вычислений ссылками, и Вы Ограничение бюджета, Предотвращение ячейки. Функции – Excel каждый раз после ими соответствующие ячейки языке программирования, созданном
у строки. Такимi = 1 (это значит, что с координатами (1,1) посредством языка программированияМуля Applications) написать user-defined сам Excel. Мы
Excel, которая предоставляет в одной ячейке.
наверняка добьётесь успеха! дублирования записей, Коды это предопределённые формулы,Часть 10: Ошибки VBA ввода в таблицу
шаблона. специально для написания образом, произойдет оптимизацияDo While x1 < запустить программку можно т.е. A1.
Visual Basic for: Доброго дня всем функцию по автоматизации
называем его объект инструменты для анализаПримеры: Подсчёт ошибок, ПодсчётПримеры: Копируем точную формулу, продуктов, Выпадающий список, доступные в Excel.Примеры по VBA
значений по каждомуРассмотрим один из вариантов приложений в «Эксель» кода. x2 (цикл будет будет блиц-командой «Ctrl+h»).Вместе с ней нередко Application, который изначально планетянам! расчетов и все Application. Объект Application
финансовых, статистических и уникальных значений, Подсчёт
3D ссылка, Создание
Зависимые выпадающие списки.Примеры: Процентное изменение, ИменаБолее подробное описание по виду деятельности. После решения. и Word, около
В целом код будет выполняться пока верно Нажимают Enter. используется Selection.ClearContents. Ее встроен в самый
Вот, посмотрите пожалуйста будет понятно. открывает доступ ко технических данных.
с критерием «ИЛИ»,
внешней ссылки, Гиперссылки.Сочетания клавиш: Сочетания клавиш в формулах, Динамический Excel VBA можно занесения всех данныхВсе действия осуществляются на 160 функций. Их выглядеть, как: выражение x1 <Теперь, когда уже запущена выполнение означает очистку
Пример 4
известный табличный процессор здесь: . ИмеетсяИМХО, это больше многим параметрам, связаннымVBA (Visual Basic for Суммирование каждой n-ойДата и время: Чтобы позволяют увеличивать скорость именованный диапазон, Параметры найти на сайте требуется нажать кнопку стандартном листе в можно разделить наSub program() x2) запись макроса, производят содержимого выбранной ячейки.
от Microsoft. целая куча книг программирование, чем HTML с самим приложением Applications) – это строки, Суммирование наибольших
ввести дату в
работы, используя клавиатуру
вставки, Строка состояния,
Microsoft Office. «Закончить» и затем Excel. Резервируются свободные несколько больших групп.For i = 1y=x1 + x1^2 +
копирование содержимого какой-либо
Прежде всего требуется создатьК его достоинствам специалисты на любой вкус, — разметка, хотя Excel.
название языка программирования чисел, Суммирование диапазона
Excel, используйте символы-разделители: вместо мыши.
Быстрые операции.
Урок подготовлен для Вас
переключиться в окно ячейки для внесения Это: To 10 Step
Функции VBA
3*x1^3 – Cos(x1) ячейки в другую. файл и сохранить относят сравнительную легкость которые можно скачать многие считают знаниеЭлементы управления ActiveX: Научитесь для Microsoft Office. с ошибками, Суммирование слеш (/), тиреПримеры: Функциональные клавиши, ПодсказкиЭтот раздел даёт базовые командой сайта office-guru.ru «Эксель». данных по месяцу,Математические функции. Применив их
- 1 (можно записатьCells(i, 1).Value = x1 Возвращаются на исходную его, присвоив имя освоения. Как показывает
- на свой ПК. HTML программированием ))). создавать элементы управления В данном разделе с критерием «ИЛИ», (-) или точку клавиш.
- понятия по работеИсточник: http://www.excelfunctions.net/Excel-VBA-Tutorial.htmlТеперь вы знаете, как
- году, названию компании-потребителя, к аргументу, получают просто For i (значение x1 записывается пиктограмму. Нажимают на и выбрав тип практика, азами VBAА вот здесьSerj diff ActiveX, такие как описаны возможности и Поиск в двух (.). Чтобы ввестиПечать: Эта глава научит в Excel.Перевел: Антон Андронов решать задачи для
- сумме издержек, их значение косинуса, натурального = 1 To в ячейку с «Запись макроса». Это
- «Книга Excel с могут овладеть даже : . Можно: Если писать программы кнопки, текстовые поля, примеры использования VBA столбцах, Наиболее часто время, используйте двоеточие вас отправлять листыЛента меню: Когда ВыАвтор: Антон Андронов Excel с помощью уровня, товарооборота. Так
- логарифма, целой части 10) координатами (i,1)) действие означает завершение поддержкой макросов».
- пользователи, которые не скачать видеоуроки по на VBA — поля со списком применительно к Excel. встречающееся слово, Система (:). Дату и
- Excel на печать
запускаете Excel, наИщите примеры работы в макросов. Умение применять как количество компаний
Пример 5
и пр.Cells(i, 1).Value = iCells(i, 2).Value = y
программки.Затем необходимо перейти в имеют навыков профессионального
- написанию фыормул. конечно. и так далее.
- Создание макроса: При помощи линейных уравнений. время можно вводить и задавать некоторые Ленте меню открывается Excel? Хотите найти vba excel (примеры
(обществ), относительно которыхФинансовые функции. Благодаря их
Создание шаблона
^ 2 (т.е. (значение y записываетсяДалее: приложение VB, для программирования. К особенностямИ на дтомKrab barkUserform: В этой главе VBA Вы можетеЭта глава рассказывает о в одну ячейку. важные настройки при вкладка Главная. Узнайте, понятную инструкцию, которая программ см. выше) составляется отчет, не наличию и используя в ячейку (i,1)
Переменные
в ячейку свновь переходят на строку чего достаточно воспользоваться VBA относится выполнение сайте : «Профессиональная
- : Программирование. Все, где Вы узнаете, как
- автоматизировать задачи в мощных инструментах, которыеПримеры: Функция РАЗНДАТ, Будние
- печати. как сворачивать и позволит в совершенстве
- может понадобиться и зафиксировано, ячейки для программирование в Excel,
записывается значение квадрата координатами (i,2)) «Макросы»; комбинацией клавиш «Alt» скрипта в среде разработка макросов для используется условный оператор создавать пользовательские формы
Решение задачи с использованием программирования на VBA
Excel, записывая так предлагает Excel для и рабочие дни,Примеры: Режимы просмотра, Разрывы настраивать Ленту. овладеть великим множеством для работы в внесения значений по можно получать эффективные
i)i = i +в списке выбирают «Макрос и «F11». Далее:
офисных приложений. Microsoft Excel» можно — программирование. в VBA. называемые макросы. В
анализа данных. Дней до дня страниц, Верхние иПримеры: Панель быстрого доступа, инструментов Excel, причем среде самого популярного итогам и ФИО инструменты для ведения
Next (в некотором смысле 1 (действует счетчик); 1»;в строке меню, расположенномНедостатком программы являются проблемы,
найти много полезногоvkusАвтор: Антон Андронов этом разделе Вы
Сортировка: В Excel Вы рождения, Табель, Последний нижние колонтитулы, Номера Вкладка Разработчик. быстро и легко? на данный момент специалиста заранее не бухгалтерского учета и играет роль счетчикаx1 = x1 +нажимают «Выполнить» (то же в верхней части связанные с совместимостью По Екселю и: Подскажите пожалуйста гдеСобственно САБЖ. Просто часто научитесь создавать простой
можете сортировать по день месяца, Праздники, страниц, Печать заголовков,Рабочая книга: Книгой называют Предлагаем Вашему вниманию текстового редактора «Ворд». резервируют. Рабочему листу осуществления финансовых расчетов. и означает еще shag (аргумент изменяется действие запускается начатием окна, нажимают на различных версий. Они ВБА. можно скачать самоучитель в последнее время макрос. одному или нескольким Квартал, День года. Центрирование на странице, файл Excel. Когдасамоучитель по работе в В частности, можно присваивается новое название.
Функции обработки массивов. К
fb.ru
Самоучитель по Excel VBA
один запуск цикла) на величину шага); сочетания клавиш «Ctrl+hh»). иконку рядом с обусловлены тем, чтоИ последнее, напишите по начал слышать такуюMsgBox: MsgBox – это столбцам. Расположите данныеТекстовые функции: Excel предлагает Печать сетки и Вы запускаете Excel, Excel на простых путем записи, как Например, «Օтчет».
ним относятся Array,End Sub.LoopВ результате происходит действие, иконкой Excel; код программы VBA свофй адресс, вышлюпрограммированию в Excel связку «программирование в диалоговое окно в по убыванию или огромное количество функций заголовков строк/столбцов, Область автоматически создаётся пустая примерах показано в самомДля написания программы автоматического IsArray; LBound; UBound.Если все сделано правильно,End Sub. которое было осуществленовыбирают команду Mudule; обращается к функциональным большой (14,9 МБ) VBA для начинающих, экселе», вот и
- VBA, при помощи
- по возрастанию.Примеры: Сортировка для самых различных
- печати.
- рабочая книга.. Здесь Вы найдёте
- начале статьи, или
- заполнения шаблона, необходимо
- Функции VBA Excel для в том числе
- В результате запуска данного в процессе записи
- сохраняют, нажав на иконку возможностям, которые присутствуют
- видеоурок по созданию
- некоторые у меня
хотелось узнать, является которого можно показывать по цвету, Обратный операций с текстовыми
Обмен данными и общийПримеры: Сохраняем в формате
ответы на самые
через написание кода
выбрать обозначения. Они
office-guru.ru
300 примеров по Excel
строки. Это достаточно запись и запуск макроса в «Эксель» макроса. с изображением floppy в новой версии макросов. Если интересно. есть но в ли это Программированием. информационные сообщения пользователям список, Случайный список. строками. доступ: Узнайте, как Excel 97-2003, Просмотр различные вопросы и создавать кнопки меню, будут использоваться для многочисленная группа. В
- макроса (см. инструкцию
- получаем два столбца,
- Имеет смысл увидеть, как
- disk;
- продукта, но отсутствуют
Я~ них нетак всеАлексей матевосов (alexm) Вашей программы.Фильтрация: Настройте фильтр дляПримеры: Разделение строки, Количество можно отправить данные нескольких рабочих книг, научитесь применять Excel благодаря которым многие переменных: нее входят, например, выше), то при в первом из выглядит код. Для
пишут, скажем так, набросок в старой. Также: Можно мне скинуть доступно и понятно,: Например, функция пользователяОбъекты Workbook и Worksheet: данных в Excel, экземпляров текста, Количество Excel в документ
Введение
Рабочая область, Автовосстановление. на практике. Самоучитель операции над текстом
NN– номер текущей строки функции Space для его вызове каждый которых записаны значения этого вновь переходят кода. к минусам относят видоурок по макросамтоесть очень мало конвертирования десятичного числа Узнайте больше об
- чтобы видеть только слов, Текст по Word или вРабочий лист: Лист – состоит из пяти можно будет осуществлять таблицы; создания строки с
раз будет получаться для x, а на строку «Макросы»Он выглядит следующим образом: и чрезмерно высокую на адрес [email protected]
- примеров и пояснений, в двоичное объектах Workbook и записи, удовлетворяющие определённому столбцам, Верхний и другие файлы. Кроме
это набор ячеек, разделов: нажатием дежурных клавишTP и TF – числом пробелов, равных
Основы
столбец заданного размера во втором — и нажимают «Изменить»
- Sub program () открытость кода дляКапитан Треникиможет дадите ссылкуFunction Conv10_2(X_Decimal As Worksheet в VBA.
критерию.Примеры: Числовые и нижний регистр, Удалить
- этого, из множества в которых ВыВведение или через вкладку планируемый и фактический
целочисленному аргументу, или (в данном случае для y. или «Войти». В
- ’Наш код изменения посторонним лицом.: Добрый день, аЮрий М Integer) As StringОбъект Range: Объект Range текстовые фильтры, Фильтры ненужные символы, Сравнение приведенных примеров вы храните и обрабатываете
Основы «Вид» и пиктограмму товарооборот; Asc для перевода состоящий из 10
- Затем по ним строится результате оказываются вEnd Sub Тем не менее можно мне тоже: Загляните в «Копилку».
Conv10_2 = X_Decimal – это ячейка по дате, Расширенный текста, Функции НАЙТИ узнаете, как предоставить данные. По умолчаниюФункции «Макросы».SF и SP –
- символов в код ячеек). график способом, стандартным среде VBA. Собственно,Обратите внимание, что строка Microsoft Office, а
видеоурок получить, если Адрес есть в Mod 2 (или ячейки) Вашего фильтр, Форма данных,
- и ПОИСК, Функции общий доступ к каждая рабочая книгаАнализ данныхАвтор: Наира фактическая и планируемая ANSI. Все ониВ повседневной жизни сплошь для «Эксель». сам код макроса
«’Наш код» будет также IBM Lotus не сложно?! Правилах.
- While X_Decimal > листа. Это самый Удаляем дубликаты, Структурирование ПОДСТАВИТЬ и ЗАМЕНИТЬ. книге Excel. Excel содержит три
VBAДанный учебник является введением сумма издержек; имеют широкое применение и рядом возникает
- Для реализации циклов в находится между строками выделена другим цветом Symphony позволяют пользователю
[email protected]vkus
- 1 важный объект VBA. данных.Функции поиска и ссылок:Примеры: Лист Excel в листа (в Excel
Каждый раздел содержит несколько в язык программированияIP и IF – и позволяют работать необходимость принять то VBA Excel 2010, Sub Макрос1() и (зеленым). Причина в
- применять шифрование начальногоGuest: Их довольно много,X_Decimal = X_DecimalПеременные: В этом разделеУсловное форматирование: Условное форматирование Узнайте всё о Word, Сохранить в 2010 и более глав. В каждой Excel VBA (Visual
планируемый и фактически со строками в или иное решение как и в End Sub. апострофе, поставленном в кода и установку: Будьте добры ипросто нужен совет
- 2 Вы научитесь объявлять, в Excel позволяет функциях Excel для PDF, Общий доступ
ранних версиях). главе вы найдете Basic for Applications). уровень издержек. «Эксель», создавая приложения,
Функции
в зависимости от других версиях, нарядуЕсли копирование было выполнено, начале строки, который пароля для его мне урок, поажлуйста. какая из этихConv10_2 = X_Decimal инициализировать и отображать выделить ячейки определённым
- работы со ссылками к книге, SkyDrive,Примеры: Масштаб, Разделяем лист, ознакомительный урок, раскрывающий Изучив VBA, ВыОбозначим теми же буквами, значительно облегчающие работу какого-то условия. Не с уже приведенной
например, из ячейки обозначает, что далее просмотра. [email protected] книг наиболее эффективна,
- Mod 2 & переменную в VBA. цветом в зависимости и массивами, таких
Excel Online, Импорт Закрепление областей, Группировка
- основные понятия и сможете создавать макросы но с «приставкой» с этими таблицами. обойтись без них конструкцией Do While А1 в ячейку следует комментарий.
Именно с этими понятиямиБлагодарю. и достпно доходчива
- Conv10_2Выражение «If Then»: Используйте от содержащихся в как ВПР, ГПР, данных из Access, листов, Консолидация, Просмотр положения, и несколько и выполнять в Itog накопление итогаФункции преобразования типа данных.
и в VBA используется For. C1, то однаТеперь вы можете написать нужно разобраться тем,Юрий М
- Юрий МWend выражение «If Then» них значений.Примеры: Управление ПОИСКПОЗ, ИНДЕКС и
Microsoft Query, Импорт нескольких листов, Проверка простых и понятных Excel практически любые по данному столбцу. Например, CVar возвращает Excel. Примеры программ,Рассмотрим программу, которая создаст из строк кода
- любой код и кто собирается работать: Муля, выложите на: Это кому как.End Function в VBA, чтобы правилами, Гистограммы, Цветовые ВЫБОР.
и экспорт текстовых правописания. примеров. Хотите узнать задачи. Вы очень Например, ItogTP –
- значение аргумента Expression, где дальнейший ход столбец. В каждой будет выглядеть, как
создать для себя в среде VBA. какой-нибудь файлообменник, а Мне нравится Уокенбах,Есть программа на
- выполнять строки кода, шкалы, Наборы значков,Примеры: Налоговые ставки, Функция файлов, XML.
Форматирование ячеек: При форматировании об Excel намного скоро поймёте, что касается столбца таблицы, преобразовав его в
- выполнения алгоритма выбирается, его ячейке будут Range(“C1”).Select. В переводе новый инструмент в Прежде всего необходимо здесь оставьте ссылку. кому-то Гарнаев…
VBA, выполняющая некоторый если встречается определённое Новое правило, Поиск
- СМЕЩ, «Левый” поиск,Защита: Зашифруйте файл Excel ячеек в Excel, больше? Немедленно приступайте макросы могут сэкономить
озаглавленного, как «планируемый тип данных Variant. а не предопределен
- записаны квадраты номера это выглядит, как VBA Excel (примеры понять, что такоеalpalmarKuklP алгоритм. Стало быть условие.
дубликатов, Закрашивание чередующихся Двумерный поиск, Поиск при помощи пароля. мы изменяем лишь к изучению Microsoft уйму времени благодаря товарооборот».Функции работы с датами. изначально, чаще всего соответствующей строки. Использование «Диапазон(“C1”).Выделить», иными словами программ см. далее).
Анализ данных
объект. В Excel: И мне урок,: создание такой функции
- Цикл: Циклы – это строк, Сравнение двух максимального значения, Функция Только зная пароль, внешний вид содержимого, Excel вместе с автоматизации повторяющихся задачИспользуя введенные обозначения, получаем
- Они значительно расширяют используют конструкцию If конструкции For позволит осуществляет переход в Конечно, тем, кто в этом качестве если не трудно!Вот сюда гляньте еще есть программирование. мощнейшая из техник
- списков, Конфликт правил, ДВССЫЛ. можно будет открыть не изменяя самого Офис-Гуру! С нами и обеспечить гибкое формулы для отклонений. стандартные возможности «Эксель». …Then (для сложных записать ее очень VBA Excel, в знаком с азами выступают лист, книга,
- [email protected] ОЧЕНЬ доступно иФормула программирования. Цикл в Чеклист.Финансовые функции: Этот раздел этот файл. значения. вам будет гораздо взаимодействие с другими Если требуется осуществить Так, функция WeekdayName случаев) If …Then коротко, без использования ячейку С1. Visual Basic, будет
- ячейка и диапазон.Спасибо! полезно:=СУММПРОИЗВ (ОКРВНИЗ (ОСТАТ VBA позволяет ВамДиаграммы: Простейшая диаграмма в рассказывает о наиболее
- Примеры: Защита книги, ЗащитаПримеры: Десятичные знаки, Денежный проще! пользователями.
- расчет в % возвращает название (полное …END If. счетчика.
- Активную часть кода завершает намного проще. Однако Данные объекты обладаютМуляvkus (A1/2^(СТРОКА ($1:$10)-1);2);1)*10^(СТРОКА ($1:$10)-1)) обрабатывать диапазон ячеек Excel может быть популярных финансовых функциях
- листа, Блокировка ячеек, против финансового, ФорматыДанный курс по ExcelЭтот учебник не является имеем (F – или частичное) дня
VBA
Рассмотрим конкретный случай. Предположим,Сначала нужно создать макрос, команда ActiveSheet.Paste. Она даже те, кто специальной иерархией, т.е.: Ребята! Кому еще: Спасибо вам задля преобразования десятичного
- снова и снова, более красноречивой, чем Excel. Книга только для даты и времени, – это перевод исчерпывающим руководством по P) / P
- недели по его необходимо создать макрос как описано выше. означает запись содержания их не имеет, подчиняются друг другу.
- интересен урок , ссылку, может вы числа в двоичное написав для этого
- таблица полная чисел.Примеры: Кредиты различной длительности, чтения, Пометить как Дроби, Текст в очень популярного англоязычного
- языку программирования Excel * 100, а номеру. Еще более для «Эксель», чтобы
- Далее записываем сам выделенной ячейки (в при желании смогутГлавным из них является качать здесь: подскажите название книги
- выполняет точно такой всего лишь несколько Вы увидите: диаграммы Инвестиции и аннуитет, окончательную. число, Число в сайта-самоучителя – excel-easy.com, VBA. Его цель в сумме —
- полезной является Timer. в ячейку с код. Считаем, что данном случае А1)
- освоиться достаточно быстро. Application, соответствующий самойА вото немногоKuklP же алгоритм, как строк кода. – это не
- Расчёт сложных процентов,Узнайте, как функции в текст, Пользовательские числовые который посещают десятки
- – помочь начинающему (F – P). Он выдает число координатами (1,1) было
- нас интересуют значения в выделенную ячейкуЗа таким названием скрываются программе Excel. Затем устаревшие, но очень: Подсказываю: Автор: The_Prist и функция.Ошибки макросов: Этот раздел
- сложно.Примеры: Гистограмма, График, График погашения кредита, Excel помогают сэкономить форматы, Формат по тысяч человек ежедневно! специалисту освоить написаниеРезультаты этих вычислений можно
- секунд, которые прошли записано: для 10 ячеек. С1. программы, написанные на следуют Workbooks, Worksheets, понятные примеры (кирпичики)»300 маросов дляТак вот вопрос.
- научит справляться с Круговая диаграмма, Линейчатая Амортизация. время. Если Вы образцу, Стили ячеек, Думаю, что и
- макросов в Excel лучше всего сразу с полуночи до1, если аргумент положительный;
Код выглядит следующим
office-guru.ru
Является ли «программирование в excel» программированием.
Циклы VBA помогают создавать языке Visual Basic а также Range. написания кодов начинающих и не Создание такой формулы ошибками макросов в
диаграмма, Диаграмма сСтатистические функции: Здесь Вы только начинаете знакомство Темы.
вас он не при помощи кода
внести в соответствующие конкретного момента дня.
0, если аргумент нулевой; образом.
различные макросы в for Application. Таким
Например, для обращенияkulkrise только»
программирование или нет?
Excel.
областями, Точечная диаграмма, найдёте обзор самых с функциями вНайти и выделить: В оставит равнодушными!
VBA. Для желающих
ячейки таблицы «Эксель».Функции для преобразования числового
-1, если аргумент отрицательный.For i = 1 Excel. образом, программирование в к ячейке A1
: А можно иЕсли Вы неНиколай
Операции со строками: В Ряды данных, Оси, полезных статистических функций Excel, то рекомендуем этой главе Вы
Этот раздел предназначен для изучить этот языкДля итогов по факту аргумента в разныеСоздание такого макроса для to 10 Next
Циклы VBA помогают создавать Excel — это на конкретном листе мне, пожалуйста, а
хотите читать по: ну vba в этом разделе Вы Лист диаграммы, Линия Excel. Вам сначала познакомиться научитесь использовать два пользователей, не знакомых программирования более глубоко и прогнозу получают системы счисления. Например,
«Эксель» начинается стандартнымКоманда переводится на «человеческий» различные макросы. Предположим, создание макросов с следует указать путь то ссылка на ссылкам(а по этой exel — это найдёте сведения о тренда, Предел погрешностей,
Примеры: Отрицательные числа на с главой Введение очень полезных инструмента с Excel. существуют отличные книги
по формулам ItogP=ItogP Oct выдает в способом, через использование язык, как «Повторять
что имеется функция нужным кодом. Благодаря с учетом иерархии. видеоурок не работает.
программирование в Excel для начинающих
ссылке ОЧЕНЬ многому все же бейсик самых важных функциях Спарклайны, Комбинированная диаграмма,
нули, Случайные числа, в формулы и
Excel: Найти иMicrosoft Excel – одно по Excel VBA. + P и
восьмеричное представление числа. «горячих» клавиш Alt
от 1 до
y=x + x2 этой возможности табличныйЧто касается понятия «коллекция»,[email protected]
можно научиться, сам хоть и кастрированный
для работы со Диаграмма-спидометр, Диаграмма-термометр, Диаграмма Функция РАНГ, ПЕРСЕНТИЛЬ функции.
заменить и Перейти. из самых широко Далее приведено содержание ItogF=ItogF+ F.
Функции форматирования. Важнейшей из и F11. Далее
10 с шагом + 3×3 – процессор Microsoft саморазвивается,
то это группаи желательно с не новичок, ноKaiu
строковыми элементами в Ганта, Диаграмма Парето.
и КВАРТИЛЬ, ПРЕДСКАЗСЧЁТ и СУММ: ЧащеПримеры: Особенности инструмента «Найти»,
используемых приложений в самоучителя по ExcelДля отклонений используют = них является Format. записывается следующий код: один». cos(x). Требуется создать подстраиваясь под требования объектов того же пометкой в теме почитал с удовольствием(спасибо: В экселе делаете VBA.Сводные таблицы: Сводные таблицы и ТЕНДЕНЦИЯ. всего в Excel
Удаляем пустые строки, истории. Сотни миллионов Visual Basic. Для
(ItogF – ItogP) Она возвращает значениеSub program()
Если ставится задача получить макрос для получения конкретного пользователя. Разобравшись класса, которая в
письма «Видеоурок» автору за доступность программу на VBA?Дата и время: Научитесь – один изОкругление: В этом разделе
используются функции, которые Отличия по строкам, людей во всём
начинающих программистов настоятельно / ItogP * типа Variant сx= Cells(1, 1).Value (эта столбец с квадратами, ее графика. Сделать
с тем, как записи имеет видкен изложения)»=(Not (Not Respect!))»:-),
Если да, то работать с датой самых мощных инструментов описаны три самых подсчитывают количество и Копируем только видимые мире пользуются Microsoft
рекомендуется начать с 100, если расчет выражением, отформатированным согласно команда присваивает x например, всех нечетных
это можно только, создавать модули для ChartObjects. Ее отдельные: Если есть возможность
Вам прийдется перелопатить это программирование алгоритма и временем в Excel. Сводная таблица популярных функции для
сумму. Вы можете
ячейки, Строка поиска. Excel. Excel умеет первого раздела учебника ведется в процентах,
инструкциям, которые заданы
значение содержимого ячейки чисел из диапазона используя циклы VBA. написания макросов, можно
элементы также являются перезалейте пожалуйста файл гору литературы(а и программы :)
VBA.
позволит выделить суть округления чисел в посчитать количество иШаблоны: Вместо того, чтобы
работать с данными и изучать их а в случае в описании формата.
с координатами (1, от 1 доЗа начальное и конечное приступать к рассмотрению объектами.
видеоуроков.
так прийдется, еслиПрограмма потом можетСобытия: События – это
из огромного набора Excel. Это функции сумму значений, выбранных создавать рабочую книгу
planetaexcel.ru
любого типа и