Vba excel вызов подпрограммы

Вызов процедур Sub (подпрограмм) из кода других процедур, расположенных в одном или разных модулях, в одной или разных книгах Excel (проектах VBA), с аргументами или без. Примеры.

Вызов подпрограммы из кода другой процедуры Sub, расположенной в том же модуле или другом модуле одной рабочей книги (проекта VBA) осуществляется с помощью ключевого слова Call или без него по имени подпрограммы. Вызывающая процедура Sub может быть любой видимости, как Public, так и Private, а вызываемая, если расположена в том же модуле, может быть любой видимости, но если расположена в другом модуле, должна быть объявлена как Public.

Синтаксис вызова подпрограмм в пределах одной книги

[ Call ] ИмяПроцедуры [ (Аргументы) ]

  • Call — необязательное ключевое слово;
  • ИмяПроцедуры — обязательный компонент, имя вызываемой подпрограммы;
  • Аргументы — необязательный компонент, список аргументов вызываемой процедуры Sub, разделенных запятой.

Вызов подпрограмм без аргументов в пределах одного модуля

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

Private Sub test1()

  Call test2

  test3

End Sub

Private Sub test2()

  MsgBox «Процедура test2 (Private) вызвана с ключевым словом Call!»

End Sub

Public Sub test3()

  MsgBox «Процедура test3 (Public) вызвана без ключевого слова Call!»

End Sub

Вы можете скопировать приведенный код в свой модуль и посмотреть, запустив процедуру test1, как она последовательно запускает процедуры test2 и test3.

Вызов подпрограмм с аргументами в пределах одного модуля

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

Private Sub test4()

  Call test5(15, 25)

  test6 256, 312, 4.52

End Sub

Sub test5(a As Single, b As Single)

  MsgBox a + b

End Sub

Sub test6(c As Single, d As Single, e As Single)

  MsgBox c + d + e

End Sub

Вы можете разместить этот код в своем модуле и протестировать его.

Вызов подпрограмм из разных модулей одной книги

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

Вызываемая подпрограмма расположена в Стандартном модуле

‘Процедура Sub с уникальным именем —

‘возможны два варианта:

УникальноеИмяПроцедуры

ИмяМодуля.УникальноеИмяПроцедуры

‘Процедура Sub с неуникальным именем —

‘возможен только один вариант:

ИмяМодуля.НеуникальноеИмяПроцедуры

  • ИмяМодуля — уникальное имя стандартного модуля, отображаемое в проводнике проекта VBA.

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

Вызываемая подпрограмма расположена в модуле книги, модуле листа, модуле формы

‘В модуле книги:

ЭтаКнига.ИмяПроцедуры

‘В модуле листа:

ИмяЛиста.ИмяПроцедуры

Worksheets(«Имя ярлычка листа»).ИмяПроцедуры

‘В модуле формы:

ИмяФормы.ИмяПроцедуры

  • ЭтаКнига — так и пишется, указывает на текущую книгу в которой расположены вызывающая и вызываемая подпрограммы.
  • ИмяЛиста — уникальное имя листа, которое в проводнике проекта VBA указано без скобок (по умолчанию: Лист1, Лист2, Лист3 и т.д.).
  • Имя ярлычка листа — дублирующее имя листа, которое в проводнике проекта VBA указано в скобках.
  • ИмяФормы — уникальное имя пользовательской формы, отображаемое в проводнике проекта VBA.

Вызов процедур Sub из модулей разных книг

Если вызываемая подпрограмма расположена в другой книге, она должна быть объявлена как Public, а книга открыта. Запустить такую процедуру Sub можно с помощью метода Application.Run (протестировано в Excel 2016).

Синтаксис метода Application.Run

Application.Run «ИмяКниги!ИмяМодуля.ИмяПроцедуры», Арг1, Арг2, …, Арг30

  1. ИмяКниги!ИмяМодуля.ИмяПроцедуры — обязательный компонент, полный адрес подпрограммы, заключен в двойные кавычки.
    • ИмяКниги — имя рабочей книги Excel с расширением, в которой находится вызываемая подпрограмма, если имя содержит пробелы, оно заключается в одинарные кавычки — апострофы (‘Имя Книги’).
    • ИмяМодуля — имя модуля для стандартного модуля (для уникальных имен вызываемых подпрограмм может не указываться), имя листа для модуля листа, словосочетание «ЭтаКнига» (без кавычек) для модуля книги.
    • ИмяПроцедуры — имя вызываемой процедуры Sub.
  2. Арг1, Арг2, …, Арг30 — необязательные компоненты, аргументы вызываемой подпрограммы, максимальное количество которых ограничено 30 элементами.

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

Полный адрес вызываемой процедуры

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

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

Список макросов во всех открытых книгах Excel

Список макросов во всех открытых книгах

2. Найдите в списке вызываемую подпрограмму и кликните по ней. Ее полный адрес отобразится в поле «Имя макроса».

3. Скопируйте полное имя вызываемой процедуры Sub и вставьте ее в метод Application.Run, заключив в двойные кавычки.

Один нюанс: в окне «Макрос» не отображаются процедуры с аргументами. Чтобы отобразить такую процедуру, закомментируйте аргументы, а после копирования и вставки раскомментируйте их.

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

Пример вызова подпрограмм из другой книги

Допустим, у нас есть рабочая книга Excel под именем «Книга1.xlsm» (или «Книга1.xls» в ранних версиях программы). В ней находятся вызываемые из другой книги процедуры Sub, перечисленные ниже.

В стандартном модуле «Module1»:

Sub Vyzov1()

  MsgBox «Запущена процедура в стандартном модуле!»

End Sub

В модуле листа «Лист1»:

Sub Vyzov2()

  MsgBox «Запущена процедура в модуле листа!»

End Sub

В модуле книги «ЭтаКнига»:

Sub Vyzov3(a As Variant, b As Variant)

  MsgBox «Запущена процедура в модуле книги!» _

  & vbNewLine & «Сумма равна: « & a + b

End Sub

Для последовательного запуска этих подпрограмм можно вставить в любой модуль другой книги Excel следующую процедуру:

Sub ProverkaVyzova()

  Application.Run «Книга1.xlsm!Vyzov1»

  Application.Run «Книга1.xlsm!Module1.Vyzov1»

  Application.Run «Книга1.xlsm!Лист1.Vyzov2»

  Application.Run «Книга1.xlsm!ЭтаКнига.Vyzov3», 555, 445

End Sub

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

И еще раз напомню, что имя книги с пробелами заключается в одинарные кавычки (апострофы):

Application.Run «‘Новая Книга 1.xlsm’!Процедура1»

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

Заключение

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

Если хотите поэкспериментировать со связанными книгами, откройте проект VBA, из которого надо установить связь с другой книгой, и выберите в главном меню «Tools» — «References…». В открывшемся окне «References — VBAProject» все открытые книги будут отображены одним словом — «VBAProject». Выделяйте по очереди строки с этим словом и внизу, в информационной рамке, смотрите, какой книге этот проект принадлежит. Поставьте галочку рядом с выбранным проектом и нажмите кнопку «OK». Если книга, с проектом которой устанавливается связь, закрыта, ее не будет в списке. В этом случае, нажмите на кнопку «Browse…», найдите, выбрав расширение, нужную книгу и откройте ее в проводнике. Связь будет установлена, и процедуры из связанных книг будут вызываться по имени с ключевым словом Call или без него, как будто они расположены в одной книге.

In this Article

  • Creating a Function without Arguments
  • Calling a Function from a Sub Procedure
  • Creating Functions
    • Single Argument
    • Multiple Arguments
    • Optional Arguments
    • Default Argument Value
    • ByVal and ByRef
  • Exit Function
  • Using a Function from within an Excel Sheet

This tutorial will teach you to create and use functions with and without parameters in VBA

VBA contains a large amount of built-in functions for you to use, but you are also able to write your own.   When you write code in VBA, you can write it in a Sub Procedure, or a Function Procedure. A Function Procedure is able to return a value to your code.  This is extremely useful if you want VBA to perform a task to return a result. VBA functions can also be called from inside Excel, just like Excel’s built-in Excel functions.

Creating a Function without Arguments

To create a function you need to define the function by giving the function a name. The function can then be defined as a data type indicating the type of data you want the function to return.

You may want to create a function that returns a static value each time it is called – a bit like a constant.

Function GetValue() As Integer
   GetValue = 50
End Function

If you were to run the function, the function would always return the value of 50.

vba function no argument

You can also create functions that refer to objects in VBA but you need to use the Set Keyword to return the value from the function.

Function GetRange() as Range
  Set GetRange = Range("A1:G4")
End Function

If you were to use the above function in your VBA code, the function would always return the range of cells A1 to G4 in whichever sheet you are working in.

Calling a Function from a Sub Procedure

Once you create a function, you can call it from anywhere else in your code by using a Sub Procedure to call the function.

vba function no argument 1

The value of 50 would always be returned.

You can also call the GetRange function from a Sub Procedure.

vba function no argument range

In the above example, the GetRange Function is called by the Sub Procedure to bold the cells in the range object.

Creating Functions

Single Argument

You can also assign a parameter or parameters to your function.  These parameters can be referred to as Arguments.

Function ConvertKilosToPounds (dblKilo as Double) as Double
   ConvertKiloToPounds = dblKilo*2.2
End Function

We can then call the above function from a Sub Procedure in order to work out how many pounds a specific amount of kilos are.

vba function return value

A function can be a called from multiple procedures within your VBA code if required.  This is very useful in that it stops you from having to write the same code over and over again.  It also enables you to divide long procedures into small manageable functions.

vba functions return values 1

In the above example, we have 2 procedures – each of them are using the Function to calculate the pound value of the kilos passed to them in the dblKilo Argument of the function.

Multiple Arguments

You can create a Function with multiple arguments and pass the values to the Function by way of a Sub Procedure.

Function CalculateDayDiff(Date1 as Date, Date2 as Date) as Double
   CalculateDayDiff = Date2-Date1
End Function

We can then call the function to calculate the amount of days between 2 dates.

vba-function-2-arguments

Optional Arguments

You can also pass Optional arguments to a Function.  In other words, sometimes you may need the argument, and sometimes you may not – depending on what code you are using the Function with .

Function CalculateDayDiff(Date1 as Date, Optional Date2 as Date) as Double
'check for second date and if not there, make Date2 equal to today's date.
   If Date2=0 then Date2 = Date
'calculate difference
   CalculateDayDiff = Date2-Date1 
End Function

vba function optional parameter

VBA Coding Made Easy

Stop searching for VBA code online. Learn more about AutoMacro — A VBA Code Builder that allows beginners to code procedures from scratch with minimal coding knowledge and with many time-saving features for all users!

automacro

Learn More

Default Argument Value

You can also set the default value of the Optional arguments when you are creating the function so that if the user omits the argument, the value that you have put as default will be used instead.

Function CalculateDayDiff(Date1 as Date, Optional Date2 as Date="06/02/2020") as Double 
'calculate difference 
   CalculateDayDiff = Date2-Date1 
End Function

vba functions optional default

ByVal and ByRef

When you pass values to a function, you can use the ByVal or ByRef keywords.  If you omit either of these, the ByRef is used as the default.

ByVal means that you are passing a copy of the variable to the function, whereas ByRef means you are referring to the original value of the variable.  When you pass a  copy of the variable (ByVal), the original value of the variable is NOT changed, but when you reference the variable, the original value of the variable is changed by the function.

Function GetValue(ByRef intA As Integer) As Integer
   intA = intA * 4
   GetValue = intA
End Function

In the function above, the ByRef could be omitted and the function would work the same way.

Function GetValue(intA As Integer) As Integer
   intA = intA * 4
   GetValue = intA
End Function

To call this function, we can run a sub-procedure.

Sub TestValues()
   Dim intVal As Integer
'populate the variable with the value 10
   intVal = 10
'run the GetValue function, and show the value in the immediate window
   Debug.Print GetValue(intVal)
'show the value of the intVal variable in the immediate window 
   Debug.Print  intVal
End Sub

vba function by ref

Note that the debug windows show the value 40 both times.  When you pass the variable IntVal to the function – the value of 10 is passed to the function, and multiplied by 4.  Using the ByRef keyword (or omitting it altogether), will AMEND the value of the IntVal variable.   This is shown when you show first the result of the function in the immediate window (40), and then the value of the IntVal variable in the debug window (also 40).

If we do NOT want to change the value of the original variable, we have to use ByVal in the function.

Function GetValue(ByVal intA As Integer) As Integer
intA = intA * 4
GetValue = intA
End Function

Now if we call the function from a sub-procedure, the value of the variable IntVal will remain at 10.

vba function byval

Exit Function

If you create a function that tests for a certain condition, and once the condition is found to be true, you want return the value from the function, you may need to add an Exit Function statement in your Function in order to exit the function before you have run through all the code in that function.

Function FindNumber(strSearch As String) As Integer
   Dim i As Integer
'loop through each letter in the string
   For i = 1 To Len(strSearch)
   'if the letter is numeric, return the value to the function
      If IsNumeric(Mid(strSearch, i, 1)) Then
         FindNumber= Mid(strSearch, i, 1)
   'then exit the function
         Exit Function
      End If
   Next
   FindNumber= 0
End Function

The function above will loop through the string that is provided until it finds a number, and then return that number from the string.  It will only find the first number in the string as it will then Exit the function.

The function above can be called by a Sub routine such as the one below.

Sub CheckForNumber()
   Dim NumIs as Integer
'pass a text string to the find number function
   NumIs = FindNumber("Upper Floor, 8 Oak Lane, Texas")
'show the result in the immediate window
   Debug.Print NumIs
End Sub

vba function exit function

VBA Programming | Code Generator does work for you!

Using a Function from within an Excel Sheet

In addition to calling a function from your VBA code using a sub procedure, you can also call the function from within your Excel sheet.  The functions that you have created should by default appear in your function list in the User Defined section of the function list.

Click on the fx to show the Insert Function dialog box.

vba function fx

Select User Defined from the Category List

vba function udf

Select the function you require from the available User Defined Functions (UDF’s).

vba function excel sheet

Alternatively, when you start writing your function in Excel, the function should appear in the drop down list of functions.

vba function dropdown

If you do not want the function to be available inside an Excel sheet, you need to put the Private word in front of the word Function when you create the function in your VBA code.

Private Function CalculateDayDiff(Date1 as Date, Date2 as Date) as Double 
   CalculateDayDiff = Date2-Date1 
End Function

It will now not appear in the drop down list showing the Excel functions available.

vba function dropdown 2

Interestingly enough, however, you can still use the function – it just will not appear in the list when looking for it!

vba function excel

If you have declared the second argument as Optional, you can omit it within the Excel sheet as well as within the VBA code.

vba function excel 2

You can also use the a function that you have created without arguments in your Excel sheet.

vba function no argument excel

Содержание

  1. Встроенные функции VBA
  2. Пользовательские процедуры «Function» и «Sub» в VBA
  3. Аргументы
  4. Необязательные аргументы
  5. Передача аргументов по значению и по ссылке
  6. VBA процедура «Function»
  7. Пример VBA процедуры «Function»: Выполняем математическую операцию с 3 числами
  8. Вызов VBA процедуры «Function»
  9. Вызов VBA процедуры «Function» из другой процедуры
  10. Вызов VBA процедуры «Function» из рабочего листа
  11. VBA процедура «Sub»
  12. VBA процедура «Sub»: Пример 1. Выравнивание по центру и изменение размера шрифта в выделенном диапазоне ячеек
  13. VBA процедура «Sub»: Пример 2. Выравнивание по центру и применение полужирного начертания к шрифту в выделенном диапазоне ячеек
  14. Вызов процедуры «Sub» в Excel VBA
  15. Вызов VBA процедуры «Sub» из другой процедуры
  16. Вызов VBA процедуры «Sub» из рабочего листа
  17. Область действия процедуры VBA
  18. Ранний выход из VBA процедур «Function» и «Sub»

Встроенные функции VBA

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

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

  • Откройте рабочую книгу Excel и запустите редактор VBA (нажмите для этого Alt+F11), и затем нажмите F2.
  • В выпадающем списке в верхней левой части экрана выберите библиотеку VBA.
  • Появится список встроенных классов и функций VBA. Кликните мышью по имени функции, чтобы внизу окна отобразилось её краткое описание. Нажатие F1 откроет страницу онлайн-справки по этой функции.

Кроме того, полный список встроенных функций VBA с примерами можно найти на сайте Visual Basic Developer Centre.

Пользовательские процедуры «Function» и «Sub» в VBA

В Excel Visual Basic набор команд, выполняющий определённую задачу, помещается в процедуру Function (Функция) или Sub (Подпрограмма). Главное отличие между процедурами Function и Sub состоит в том, что процедура Function возвращает результат, процедура Sub – нет.

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

Аргументы

При помощи аргументов процедурам VBA могут быть переданы различные данные. Список аргументов указывается при объявлении процедуры. К примеру, процедура Sub в VBA добавляет заданное целое число (Integer) в каждую ячейку в выделенном диапазоне. Передать процедуре это число можно при помощи аргумента, вот так:

Sub AddToCells(i As Integer)

...

End Sub

Имейте в виду, что наличие аргументов для процедур Function и Sub в VBA не является обязательным. Для некоторых процедур аргументы не нужны.

Необязательные аргументы

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

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

Sub AddToCells(Optional i As Integer = 0)

В таком случае целочисленный аргумент i по умолчанию будет равен 0.

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

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

Аргументы в VBA могут быть переданы процедуре двумя способами:

  • ByVal – передача аргумента по значению. Это значит, что процедуре передаётся только значение (то есть, копия аргумента), и, следовательно, любые изменения, сделанные с аргументом внутри процедуры, будут потеряны при выходе из неё.
  • ByRef – передача аргумента по ссылке. То есть процедуре передаётся фактический адрес размещения аргумента в памяти. Любые изменения, сделанные с аргументом внутри процедуры, будут сохранены при выходе из процедуры.

При помощи ключевых слов ByVal или ByRef в объявлении процедуры можно задать, каким именно способом аргумент передаётся процедуре. Ниже это показано на примерах:

Sub AddToCells(ByVal i As Integer)

...

End Sub
В этом случае целочисленный аргумент i передан по значению. После выхода из процедуры Sub все сделанные с i изменения будут утрачены.
Sub AddToCells(ByRef i As Integer)

...

End Sub
В этом случае целочисленный аргумент i передан по ссылке. После выхода из процедуры Sub все сделанные с i изменения будут сохранены в переменной, которая была передана процедуре Sub.

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

Перед тем как продолжить изучение процедур Function и Sub более подробно, будет полезным ещё раз взглянуть на особенности и отличия этих двух типов процедур. Далее приведены краткие обсуждения процедур VBA Function и Sub и показаны простые примеры.

VBA процедура «Function»

Редактор VBA распознаёт процедуру Function, когда встречает группу команд, заключённую между вот такими открывающим и закрывающим операторами:

Function

...

End Function

Как упоминалось ранее, процедура Function в VBA (в отличие от Sub), возвращает значение. Для возвращаемых значений действуют следующие правила:

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

Это отлично проиллюстрировано в следующем примере.

Пример VBA процедуры «Function»: Выполняем математическую операцию с 3 числами

Ниже приведён пример кода VBA процедуры Function, которая получает три аргумента типа Double (числа с плавающей точкой двойной точности). В результате процедура возвращает ещё одно число типа Double, равное сумме первых двух аргументов минус третий аргумент:

Function SumMinus(dNum1 As Double, dNum2 As Double, dNum3 As Double) As Double

   SumMinus = dNum1 + dNum2 - dNum3

End Function

Эта очень простая VBA процедура Function иллюстрирует, как данные передаются процедуре через аргументы. Можно увидеть, что тип данных, возвращаемых процедурой, определён как Double (об этом говорят слова As Double после списка аргументов). Также данный пример показывает, как результат процедуры Function сохраняется в переменной с именем, совпадающим с именем процедуры.

Вызов VBA процедуры «Function»

Если рассмотренная выше простая процедура Function вставлена в модуль в редакторе Visual Basic, то она может быть вызвана из других процедур VBA или использована на рабочем листе в книге Excel.

Вызов VBA процедуры «Function» из другой процедуры

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

Sub main()

   Dim total as Double
   total = SumMinus(5, 4, 3)

End Sub

Вызов VBA процедуры «Function» из рабочего листа

VBA процедуру Function можно вызвать из рабочего листа Excel таким же образом, как любую другую встроенную функцию Excel. Следовательно, созданную в предыдущем примере процедуру FunctionSumMinus можно вызвать, введя в ячейку рабочего листа вот такое выражение:

=SumMinus(10, 5, 2)

VBA процедура «Sub»

Редактор VBA понимает, что перед ним процедура Sub, когда встречает группу команд, заключённую между вот такими открывающим и закрывающим операторами:

VBA процедура «Sub»: Пример 1. Выравнивание по центру и изменение размера шрифта в выделенном диапазоне ячеек

Рассмотрим пример простой VBA процедуры Sub, задача которой – изменить форматирование выделенного диапазона ячеек. В ячейках устанавливается выравнивание по центру (и по вертикали, и по горизонтали) и размер шрифта изменяется на заданный пользователем:

Sub Format_Centered_And_Sized(Optional iFontSize As Integer = 10)

   Selection.HorizontalAlignment = xlCenter
   Selection.VerticalAlignment = xlCenter
   Selection.Font.Size = iFontSize

End Sub

Данная процедура Sub выполняет действия, но не возвращает результат.

В этом примере также использован необязательный (Optional) аргумент iFontSize. Если аргумент iFontSize не передан процедуре Sub, то его значение по умолчанию принимается равным 10. Однако же, если аргумент iFontSize передается процедуре Sub, то в выделенном диапазоне ячеек будет установлен размер шрифта, заданный пользователем.

VBA процедура «Sub»: Пример 2. Выравнивание по центру и применение полужирного начертания к шрифту в выделенном диапазоне ячеек

Следующая процедура похожа на только что рассмотренную, но на этот раз, вместо изменения размера, применяется полужирное начертание шрифта в выделенном диапазоне ячеек. Это пример процедуры Sub, которой не передаются никакие аргументы:

Sub Format_Centered_And_Bold()

   Selection.HorizontalAlignment = xlCenter
   Selection.VerticalAlignment = xlCenter
   Selection.Font.Bold = True

End Sub

Вызов процедуры «Sub» в Excel VBA

Вызов VBA процедуры «Sub» из другой процедуры

Чтобы вызвать VBA процедуру Sub из другой VBA процедуры, нужно записать ключевое слово Call, имя процедуры Sub и далее в скобках аргументы процедуры. Это показано в примере ниже:

Sub main()

   Call Format_Centered_And_Sized(20)

End Sub

Если процедура Format_Centered_And_Sized имеет более одного аргумента, то они должны быть разделены запятыми. Вот так:

Sub main()

   Call Format_Centered_And_Sized(arg1, arg2, ...)

End Sub

Вызов VBA процедуры «Sub» из рабочего листа

Процедура Sub не может быть введена непосредственно в ячейку листа Excel, как это может быть сделано с процедурой Function, потому что процедура Sub не возвращает значение. Однако, процедуры Sub, не имеющие аргументов и объявленные как Public (как будет показано далее), будут доступны для пользователей рабочего листа. Таким образом, если рассмотренные выше простые процедуры Sub вставлены в модуль в редакторе Visual Basic, то процедура Format_Centered_And_Bold будет доступна для использования на рабочем листе книги Excel, а процедура Format_Centered_And_Sized – не будет доступна, так как она имеет аргументы.

Вот простой способ запустить (или выполнить) процедуру Sub, доступную из рабочего листа:

  • Нажмите Alt+F8 (нажмите клавишу Alt и, удерживая её нажатой, нажмите клавишу F8).
  • В появившемся списке макросов выберите тот, который хотите запустить.
  • Нажмите Выполнить (Run)

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

  • Нажмите Alt+F8.
  • В появившемся списке макросов выберите тот, которому хотите назначить сочетание клавиш.
  • Нажмите Параметры (Options) и в появившемся диалоговом окне введите сочетание клавиш.
  • Нажмите ОК и закройте диалоговое окно Макрос (Macro).

Внимание: Назначая сочетание клавиш для макроса, убедитесь, что оно не используется, как стандартное в Excel (например, Ctrl+C). Если выбрать уже существующее сочетание клавиш, то оно будет переназначено макросу, и в результате пользователь может запустить выполнение макроса случайно.

Область действия процедуры VBA

В части 2 данного самоучителя обсуждалась тема области действия переменных и констант и роль ключевых слов Public и Private. Эти ключевые слова так же можно использовать применительно к VBA процедурам:

Public Sub AddToCells(i As Integer)

...

End Sub
Если перед объявлением процедуры стоит ключевое слово Public, то данная процедура будет доступна для всех модулей в данном проекте VBA.
Private Sub AddToCells(i As Integer)

...

End Sub
Если перед объявлением процедуры стоит ключевое слово Private, то данная процедура будет доступна только для текущего модуля. Её нельзя будет вызвать, находясь в любом другом модуле или из рабочей книги Excel.

Помните о том, что если перед объявлением VBA процедуры Function или Sub ключевое слово не вставлено, то по умолчанию для процедуры устанавливается свойство Public (то есть она будет доступна везде в данном проекте VBA). В этом состоит отличие от объявления переменных, которые по умолчанию бывают Private.

Ранний выход из VBA процедур «Function» и «Sub»

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

Function VAT_Amount(sVAT_Rate As Single) As Single

   VAT_Amount = 0
   If sVAT_Rate <= 0 Then
      MsgBox "Expected a Positive value of sVAT_Rate but Received " & sVAT_Rate
      Exit Function
   End If

...

End Function

Обратите внимание, что перед тем, как завершить выполнение процедуры FunctionVAT_Amount, в код вставлена встроенная VBA функция MsgBox, которая показывает пользователю всплывающее окно с предупреждением.

Оцените качество статьи. Нам важно ваше мнение:

Что такое подпрограмма?

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

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

В этом уроке вы узнаете

  • Зачем использовать подпрограммы
  • Правила именования подпрограмм и функций
  • Синтаксис подпрограммы VBA
  • Как вызвать подпрограмму в VBA

Зачем использовать подпрограммы

  • Разбейте код на небольшой управляемый код : средняя компьютерная программа имеет тысячи и тысячи строк исходного кода. Это вводит сложность. Подпрограммы помогают решить эту проблему, разбивая программу на небольшие управляемые куски кода.
  • Повторное использование кода . Допустим, у вас есть программа, которая нуждается в доступе к базе данных, почти все окна в программе должны будут взаимодействовать с базой данных. Вместо того, чтобы писать отдельный код для этих окон, вы можете создать функцию, которая обрабатывает все взаимодействия с базой данных. Затем вы можете вызвать его из любого окна.
  • Подпрограммы и функции самодокументируются . Допустим, у вас есть функция CalculateLoanInterest и другая, которая сообщает connectToDatabase. Просто взглянув на название подпрограммы / функции, программист сможет сказать, что делает программа.

Правила именования подпрограмм и функций

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

  • Имя подпрограммы или функции не может содержать пробел
  • Имя подпрограммы или функции должно начинаться с буквы или символа подчеркивания. Не может начинаться с цифры или специального символа
  • Имя подпрограммы или функции не может быть ключевым словом. Ключевое слово – это слово, которое имеет особое значение в VBA. Такие слова, как Private, Sub, Function, End и т. Д., Являются примерами ключевых слов. Компилятор использует их для конкретных задач.

Синтаксис подпрограммы VBA

Вам нужно будет включить вкладку «Разработчик» в Excel, чтобы следовать этому примеру. Если вы не знаете, как включить вкладку «Разработчик», прочтите руководство по VBA Operators.

ЗДЕСЬ в синтаксисе,

Private Sub mySubRoutine(ByVal arg1 As String, ByVal arg2 As String)
    'do something
End Sub

Синтаксическое объяснение

Код

действие

  • “Private Sub mySubRoutine (…)”
  • Здесь ключевое слово «Sub» используется для объявления подпрограммы с именем «mySubRoutine» и запуска тела подпрограммы.
  • Ключевое слово Private используется для указания области действия подпрограммы.
  • «ByVal arg1 As String, ByVal arg2 As String»:
  • Он объявляет два параметра строкового типа данных имя arg1 и arg2
  • “End Sub”
  • «End Sub» используется для завершения тела подпрограммы

Следующая подпрограмма принимает имя и фамилию и отображает их в окне сообщения.

Теперь мы собираемся запрограммировать и выполнить эту подпроцедуру. Давай посмотрим это.

Как вызвать подпрограмму в VBA

  1. Разработайте пользовательский интерфейс и установите свойства для пользовательских элементов управления.
  2. Добавить подпрограмму
  3. Напишите код события click для командной кнопки, которая вызывает подпрограмму
  4. Протестируйте приложение

Шаг 1) Пользовательский интерфейс

Дизайн пользовательского интерфейса, как показано на рисунке ниже

Функции VBA и подпрограмма

Установите следующие свойства. Свойства, которые мы устанавливаем

S / N контроль Имущество Ценность
1 CommandButton1 имя btnDisplayFullName
2 титр Полное имя подпрограммы

Ваш интерфейс должен выглядеть следующим образом

Функции VBA и подпрограмма

Шаг 2) Добавьте подпрограмму

  1. Нажмите Alt + F11, чтобы открыть окно кода
  2. Добавьте следующую подпрограмму
Private Sub displayFullName(ByVal firstName As String, ByVal lastName As String)
    MsgBox firstName & " " & lastName
End Sub

ЗДЕСЬ в коде,

Код

действия

  • “Private Sub displayFullName (…)”
  • Он объявляет приватную подпрограмму displayFullName, которая принимает два строковых параметра.
  • “ByVal firstName As String, ByVal lastName As String”
  • Он объявляет две переменные параметра firstName и lastName
  • MsgBox firstName & “” & lastName “
  • Он вызывает встроенную функцию MsgBox для отображения окна сообщения. Затем он передает переменные ‘firstName’ и ‘lastName’ в качестве параметров.
  • Амперсанд «&» используется для объединения двух переменных и добавления пустого пространства между ними.

Шаг 3) Вызов подпрограммы из события нажатия кнопки.

  • Щелкните правой кнопкой мыши на кнопке, как показано на рисунке ниже. Выберите Просмотр кода.
  • Откроется редактор кода

Функции VBA и подпрограмма

Добавьте следующий код в редакторе кода для события click кнопки btnDisplayFullName.

Private Sub btnDisplayFullName_Click()
    displayFullName "John", "Doe"
End Sub

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

Функции VBA и подпрограмма

Сохраните изменения и закройте окно кода.

Шаг 4) Тестирование кода

На панели инструментов разработчика установите режим «выключен». Как показано ниже.

Функции VBA и подпрограмма

Шаг 5) Нажмите на командную кнопку «Полное имя подпрограммы».

Вы получите следующие результаты

Функции VBA и подпрограмма

Загрузите приведенный выше код Excel

Резюме:

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

В отличии от языка VBScript, VBA процедуры классифицируются не на два типа (процедура-функция и процедура-подпрограмма), а четырех типов: процедура-функция, процедура-подпрограмма, процедура свойств и обработка событий. Также существуют некоторые дополнения в плане передачи параметров (по значению или по ссылке). Третьим моментом является область видимости – в VBA вызов процедуры может осуществляться как в пределах текущего модуля (макроса), так и за его пределами – во всех проектах. Все это обусловлено тем, что VBA – это не столько язык программирования, сколько программный пакет, с возможностью создания форм и проектов.

Давайте сначала кратко рассмотрим типы VBA процедур:

Подпрограммы – блоки кода заключенные в конструкцию Sub …. End Sub. Сама по себе подпрограмма не возвращает никакого значения, а просто выполняет прописанные в ней команды.

Функции – также блок кода, но прописанный в конструкцию Function … End Function. После выполнения функции возвращается определенное значение, доступ к которому можно получить через имя VBA функции.

Помимо этого, стоит упомянуть про обработку событий (нажатие кнопки клавиатуры или перемещение мыши) и доступ к объектам, но это отдельная тема.

VBA процедуры типа Sub – подпрограммы

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

Sub ИмяПодпрограмм([аргументы])
Операторы
[Exit Sub]
операторы
End Sub

После ключевого слова Sub следует имя подпрограммы, в круглых скобках можно указывать или не указывать аргументы. Аргументы – это переменные (параметры), значение которых может обрабатываться, аргументы разделяются запятыми. Конструкция Exit Sub также не является обязательной, она говорит  том, что нужно произвести выход из подпрограммы и продолжить выполнение кода, следующего после выражения End Sub.

Вызов VBA процедуры осуществляется с помощью ключевого слова call, например, Call MySub.

Давайте напишем простой пример: добавьте в проект новую форму и новый модуль. На поверхность формы добавьте два текстовых поля (TextBox), одну метку (Label) и одну кнопку (CommandButton). Создайте связь между формой и модулем, прописав в редакторе кода для модуля:

Sub SubModule()
    SubForm.Show
End Sub

Я назвал форму SubForm, а модуль – SubModule, за имя отвечает свойство Name.

vba вызов процедуры

Теперь в редакторе кода для формы пропишите:

'************************************
' Вычисление гипотенузы
'************************************
 
' процедура VBA принимает два параметра
Sub Hipotenuze(a, b)
Dim c
    ' Проверка, если значения равны нулю
    If TextBox1.Text = 0 Or TextBox2.Text = 0 Then
        a = 1: b = 1
    End If
    ' вычисление гипотенузы
    c = Sqr(a ^ 2 + b ^ 2)
    Label1.Caption = "Гипотенуза: " & c
End Sub
 
' Обработка нажатия на кнопку
Private Sub CommandButton1_Click()
Dim Ta, Tb
    Ta = TextBox1.Text
    Tb = TextBox2.Text
    ' vba вызов процедуры Hipotenuze
    Call Hipotenuze(Ta, Tb)
End Sub
 
' Настройка свойств при запуске формы
Private Sub UserForm_Initialize()
    Label1.Caption = ""
    Label1.FontSize = 15
    Label1.ForeColor = vbBlue
    CommandButton1.Caption = "Найти"
    TextBox1.Text = 5
    TextBox2.Text = 5
End Sub

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

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

Sub MySub (a As Integer, b As String) … End Sub

Дополнительные особенности:

Static – данное ключевое слово, прописанное перед ключевым словом Sub позволяет сохранять в памяти значения всех переменных после выполнения процедуры. Его мы рассматривали в с статье – переменные VBA.

ParamArray – данное ключевое слово позволяет передавать процедуре переменное количество параметров, оно может использоваться только для последнего элемента в списке аргументов.

Ключевое слово ParamArray

ParamArray нельзя использовать вместе со словами ByRef, ByVal или Optional, например:

'************************************
' Передача параметров
'************************************
 
' процедура VBA принимает два параметра
Sub MyArguments(a As Integer, ParamArray b())
Dim elem, s As String
    Label1.Caption = a
    For Each elem In b
        s = s & elem & " "
    Next
    Label2.Caption = s
End Sub
 
' Обработка нажатия на кнопку
Private Sub CommandButton1_Click()
    MyArguments 1, 5, 6, 100, "строка"
End Sub
 
' Настройка свойств при запуске формы
Private Sub UserForm_Initialize()
    Label1.Caption = ""
    Label1.FontSize = 15
    Label1.ForeColor = vbBlue
 
    Label2.Caption = ""
    Label2.FontSize = 15
    Label2.ForeColor = vbRed
    CommandButton1.Caption = "Вывести"
End Sub

Как видим, мы фактически с помощью ParamArray показываем, что передаем массив, для его обработки мы использовали оператор For …. Each. Тут мы передали при вызове VBA процедуры пять параметров, при этом, первый будет храниться в аргументе a, а остальные в аргументе b, который обрабатывается как массив.

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

VBA Sub и Function

Например:

'************************************
' Передача параметров
'************************************
 
Sub MyArguments(Optional a As Integer = 5, Optional b As String = " плюс ", Optional c As Integer = 10)
    Label1.Caption = a & b & c
End Sub
 
Private Sub CommandButton1_Click()
    MyArguments
End Sub
Private Sub CommandButton2_Click()
    MyArguments 100, " минус ", 50
End Sub
Private Sub CommandButton3_Click()
    MyArguments 20, , 30
End Sub
 
Private Sub UserForm_Initialize()
    Label1.Caption = ""
    Label1.FontSize = 15
    Label1.ForeColor = vbBlue
 
    CommandButton1.Caption = "Вариант 1"
    CommandButton2.Caption = "Вариант 2"
    CommandButton3.Caption = "Вариант 3"
End Sub

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

Передача параметров по ссылке и по значению – по умолчанию, при вызове процедуры все параметры ей передаются по ссылке. Передача по ссылке – в простом варианте, это передача адреса по которому хранится значение. При передаче параметра по ссылке, передается не адрес, а копия значения.

Передача VBA параметров по ссылке и по значению

Что бы все стало понятно, рассмотрим следующий пример:

'************************************
' Передача параметров
'************************************
 
Sub MySub1()
Dim MyVar
    MyVar = 100
    Call MySumm1(MyVar)
    Label1.Caption = "Передача по ссылке " & MyVar
End Sub
 
Sub MySub2()
Dim MyVar
    MyVar = 100
    Call MySumm2(MyVar)
    Label2.Caption = "Передача по значению " & MyVar
End Sub
 
Sub MySumm1(ByRef a)
 a = a + 100
End Sub
Sub MySumm2(ByVal a)
 a = a + 100
End Sub
 
Private Sub CommandButton1_Click()
    MySub1
    MySub2
End Sub
 
Private Sub UserForm_Initialize()
    Label1.Caption = ""
    Label1.FontSize = 15
    Label1.ForeColor = vbBlue
 
    Label2.Caption = ""
    Label2.FontSize = 15
    Label2.ForeColor = vbRed
 
    CommandButton1.Caption = "Проверить"
End Sub

MySub1 – тут происходит объявление переменной MyVar и присвоение ей значения 100, далее в теле происходит вызов VBA процедуры MySumm1, ей в качестве параметры мы передаем значение переменной MyVar – 100. Сама процедура MySumm принимает значение по ссылке, на что указывает ключевое слово ByRef, к принятому значению прибавляется число 100. Стоит обратить внимание, что ByRef можно было и не писать. После VBA вызова процедуры MySumm1 происходит запись значения переменной MyVar в свойство Caption объекта Label1, в итоге, отобразится число 200.

MySub2 – аналог предыдущей процедуры, но тут происходит вызов MySumm2, в которой происходит передача параметров по значению, о чем говорит ключевое слово ByVal, в итоге, значение переменной MyVar не изменится.

VBA процедуры типа Function – функции

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

Function ИмяФункции ([аргументы]) [As ТипДанных]
Операторы
[Exit Function]
Операторы
[ИмяФункции=Выражение]
End Function

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

Function Summ(a As Integer, b As Integer) As Integer
    Summ = a + b
End Function
 
Private Sub CommandButton1_Click()
    Label1.Caption = "Сумма 10 и 20: " & Summ(10, 20)
End Sub
 
Private Sub UserForm_Initialize()
    Label1.Caption = ""
    Label1.FontSize = 15
    Label1.ForeColor = vbBlue
    CommandButton1.Caption = "Сумма"
End Sub

Процедура — это последовательность операторов VBA, расположенная в модуле VBA, доступ к которому можно получить с помощью VBE. Модуль может включать любое количество процедур.[1] Некоторые процедуры получают аргументы. Аргумент — это информация, используемая процедурой в процессе выполнения. Аргументы процедуры во многом подобны аргументам, используемым функциями Excel.

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

[Private | Public][Static] Sub имя([список_аргументов])
    [инструкции]
    [Exit Sub]
    [инструкции]
End Sub

Рис. 1. Запуск процедуры из Visual Basic Editor

Скачать заметку в формате Word или pdf

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

Public (необязательное ключевое слово). Указывает на то, что процедура доступна для всех остальных процедур во всех модулях рабочей книги. При использовании в модуле, содержащем оператор Option Private Module, процедура будет недоступна за пределами проекта.

Static (необязательное ключевое слово). Указывает на то, что переменные процедуры сохраняются после окончания процедуры.

Sub (обязательное ключевое слово). Обозначает начало процедуры.

Имя. Любое корректное название процедуры.

Список_аргументов. Представляет заключенный в скобки список переменных, содержащих аргументы, которые передаются в процедуру. Для разделения аргументов используется запятая. Если процедура не использует аргументы, то необходимо включить в объявление процедуры пустые скобки.

Инструкции (необязательные). Корректные инструкции VBA.

Exit Sub (необязательный оператор). Вызывает немедленный выход из процедуры до ее формального завершения.

End Sub (обязательный оператор). Указывает на завершение процедуры.

Выполнение процедуры

Основные способы выполнения, или вызова, процедуры VBA.

1-й способ. С помощью команды Run–>Run Sub/UserForm (Выполнить –> Выполнить процедуру/ пользовательскую форму, рис. 1) в VBE. Альтернатива — нажать <F5> либо воспользоваться кнопкой Run Sub/UserForm панели инструментов Standard (Стандартная, рис. 2).

Рис. 2. Кнопка Run Sub/UserForm на панели Standard VBE

2-й способ. Из диалогового окна Макрос в Excel (рис. 3). Чтобы вызвать окно пройдите по меню Разработчик –> Макрос или нажмите Alt+F8.

Рис. 3. Диалоговое окно Макрос в Excel

3-й способ. С помощью комбинации клавиши <Ctrl> и присвоенной процедуре клавиши (если процедуре присвоена комбинация клавиш). Если в момент создания процедуры ей не была присвоена клавиша, сделать это никогда не поздно. Откройте окно Макрос, как описано выше, выделите процедуру в окне Имя макроса, кликните Параметры, и введите букву в окне Сочетание клавиш (рис. 4).

Рис. 4. Присвоение процедуре комбинации клавиш

4-й способ. Щелкнув на кнопке или любой фигуре рабочего листа. Для этого кнопке или фигуре должна быть присвоена процедура (рис. 5).

Рис. 5. Назначение макроса фигуре

5-й способ. Из другой процедуры. Процедуры Sub и Function могут вызывать другие процедуры.

6-й способ. С помощью пользовательского элемента управления, находящегося на ленте. Кроме того, встроенные элементы управления ленты могут быть «перенастроены» для вызова макроса на выполнение.

7-й способ. Из пользовательского контекстного меню.

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

9-й способ. Из окна отладки (Immediate) в VBE. Просто введите название процедуры, укажите все необходимые аргументы и нажмите клавишу <Enter>.

Передача аргументов процедурам

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

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

  • По ссылке. При передаче аргумента по ссылке (метод, применяемый по умолчанию) процедуре передается адрес ячейки памяти, в которой хранится переменная. Поэтому изменение аргумента в процедуре приводит к изменению исходной переменной.
  • По значению. Передача аргумента по значению фактически означает передачу процедуре копии исходной переменной. Следовательно, изменение аргумента при выполнении процедуры не отражается на исходной переменной.

В следующем примере аргумент процедуры Process передается по ссылке (по умолчанию). После того как процедура Main присваивает переменной MyValue значение 10, она вызывает процедуру Process и передает MyValue в качестве аргумента. Процедура Process умножает значение своего аргумента (с названием YourValue) на 10. По окончании процедуры Process возобновляется выполнение процедуры Main, а функция MsgBox отображает строку MyValue: 100.

Sub Main ()
    Dim MyValue As Integer
    MyValue = 10
    Call Process(MyValue)
    MsgBox MyValue
End Sub

Sub Process (YourValue)
    YourValue = YourValue * 10
End Sub

Если требуется, чтобы вызываемая процедура не изменяла переменные, полученные как аргументы, измените список аргументов вызываемой процедуры так, чтобы аргументы передавались по значению, а не по ссылке. Для этого добавьте перед аргументом ключевое слово ByVal. Тогда вызываемая процедура будет управлять копией переданных данных, а не самими данными. В следующей процедуре, например, изменения, которые происходят с YourValue в процедуре Process, не влияют на значение переменной MyValue в процедуре Main. В результате функция MsgBox отображает 10, а не 100.

Sub Process(ByVal YourValue)
    YourValue = YourValue * 10
End Sub

Обработка ошибок

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

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

Чтобы программа продолжала выполняться после возникновения ошибки, необходимо вставить в начало процедуры оператор On Error Resume Next. При возникновении ошибки можно использовать объект Err для определения ее номера. Например, на рис. 6 представлена процедура, присваивающая Листу2 имя Исходные данные. Однако, в книге может не быть Листа2. В этом случае появится сообщение об ошибке.

Рис. 6. Процедура присвоения имени Листу Excel, обрабатывающая ошибку

Ссылка на Err эквивалентна обращению к свойству Number объекта Err. Следовательно, два приведенных ниже оператора идентичны:

MsgBox Err
MsgBox Err.Number

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

On Error GoTo ErrorHandler

Следующая процедура выделяет все ячейки в текущем диапазоне, содержащие формулы, возвращающие число. Процедура также использует оператор If для определения результата: произошла ли ошибка. Оператор On Error GoTo 0 восстанавливает нормальную обработку ошибок перед выходом из процедуры.

Sub SelectFormulas2()
    On Error Resume Next
    Selection.SpecialCells(xlFormulas, xlNumbers).Select
    If Err.Number = 1004 Then MsgBox "He найдены ячейки с формулами."
    On Error GoTo 0
    ' …[код]
End Sub

Если свойство Number объекта Err не равно 0, происходит ошибка. С помощью оператора If проверяется, не равно ли свойство Err.Number 1004, и, если это так, отображается окно сообщения. В рассмотренном примере осуществляется проверка кода на предмет обнаружения ошибки с указанным номером.

В следующем примере кода демонстрируется обработка ошибок путем перехода по метке.

Sub ErrorDemo()
    On Error GoTo Handler
    Selection.Value = 123
Exit Sub
Handler:
    MsgBox "Невозможно присвоить значение выделенному диапазону."
End Sub

В процедуре предпринимается попытка присвоить значение текущему выделенному объекту. Если происходит ошибка (например, не выделен диапазон ячеек или лист защищен), то оператор присваивания выдает ошибку. Оператор On Error задает переход к метке Handler в случае ошибки. Обратите внимание, что перед меткой используется оператор Exit Sub. Программа обработки не выполняется, если ошибок не было.

[1] По материалам книги Джон Уокенбах. Excel 2010. Профессиональное программирование на VBA. – М: Диалектика, 2013. – С. 253–273.

Процедуры «Function» и «Sub» в VBA

Встроенные функции VBA

​Смотрите также​Параметры​ и запустил выполнение​ на языке VBA)​Функции работы с объектами​Функции обработки строк​ * 100, а​If x>0 Then Cells(1,​Do While x1 <​

​ иконку рядом с​Для многомерных массивов​True​

  • ​равно​Перевел: Антон Андронов​, доступную из рабочего​ при помощи простого​​ByRef​​Перед тем, как приступить​​(Options)​​ тех же действий​
  • ​ хранятся в программных​GetObject​UCase​​ в сумме —​​ 1).Value = 1​
  • ​ x2 (цикл будет​ иконкой Excel;​ в качестве необязательного​, если заданное значение​True​Автор: Антон Андронов​ листа:​​ присваивания этой процедуры​​в объявлении процедуры​ к созданию собственных​

​позволяет посмотреть и​ еще раз. Естественно​ модулях. В любой​Функции работы с объектами​Функции обработки строк​ (F – P).​

Пользовательские процедуры «Function» и «Sub» в VBA

​If x=0 Then Cells(1,​ выполняться пока верно​выбирают команду Mudule;​ аргумента может быть​​ является датой, или​​.​​При написании кода VBA​​Нажмите​ переменной. В следующем​​ можно задать, каким​​ функций VBA, полезно​​ отредактировать сочетание клавиш​​ у такого способа​ книге Excel мы​​IsObject​​Val​​Результаты этих вычислений можно​​ 1).Value = 0​

​ выражение x1 <​сохраняют, нажав на иконку​ указано, индекс какого​False​В приведённой выше таблице​ в Excel набор​​Alt+F8​​ примере показано обращение​ именно способом аргумент​ знать, что Excel​ для быстрого запуска​ есть свои плюсы​ можем создать любое​​Функции работы с объектами​​Функции обработки строк​

Аргументы

​ лучше всего сразу​If x​ x2)​ с изображением floppy​ именно измерения нужо​– если датой​​ перечислены не все​​ встроенных операторов используют​(нажмите клавишу​ к процедуре​ передаётся процедуре. Ниже​ VBA располагает обширной​ макроса.​ и минусы:​ количество программных модулей​

​DDB​CBool​ внести в соответствующие​

​End Sub.​y=x1 + x1^2 +​ disk;​​ возвратить. Если не​​ не является.​​ логические операторы, доступные​​ на каждом шагу.​Alt​SumMinus​ это показано на​

Необязательные аргументы

​ коллекцией готовых встроенных​Кнопка​Макрорекордер записывает только те​ и разместить там​Финансовые функции​Функции преобразования типа данных​ ячейки таблицы «Эксель».​Остается запустить макрос и​ 3*x1^3 – Cos(x1)​

​пишут, скажем так, набросок​ указано, то по​Пример:​ в VBA. Полный​ Эти операторы делятся​

​и, удерживая её​, которая была определена​ примерах:​

​ функций, которые можно​Изменить​​ действия, которые выполняются​​ наши макросы. Один​FV​

​CByte​Для итогов по факту​ получить в «Эксель»​Cells(i, 1).Value = x1​ кода.​

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

​ умолчанию равно 1.​IsDate(«01/01/2015»)​ список логических операторов​

  • ​ на математические, строковые,​​ нажатой, нажмите клавишу​ выше.​Sub AddToCells(ByVal i As​ использовать при написании​(Edit)​ в пределах окна​ модуль может содержать​Финансовые функции​Функции преобразования типа данных​ и прогнозу получают​ нужное значение для​
  • ​ (значение x1 записывается​​Он выглядит следующим образом:​Year​возвращает​ можно найти на​ операторы сравнения и​F8​Sub main() Dim​ Integer) … End​ кода.​открывает редактор Visual​

​ Microsoft Excel. Как​​ любое количество макросов.​​IPmt​​CCur​​ по формулам ItogP=ItogP​ аргумента.​ в ячейку с​Sub program ()​Возвращает целое число, соответствующее​True​

​ сайте Visual Basic​ логические. Далее мы​).​ ​ total as Double​ Sub​​Список этих функций можно​​ Basic (см. выше)​ только вы закрываете​ Доступ ко всем​​Финансовые функции​​Функции преобразования типа данных​​ + P и​​Как вы уже могли​
​ координатами (i,1))​’Наш код​ году в заданной​ ​;​ Developer Center.​​ подробно рассмотрим каждую​​В появившемся списке макросов​ total = SumMinus(5,​В этом случае целочисленный​​ посмотреть в редакторе​​ и позволяет просмотреть​​ Excel или переключаетесь​​ модулям осуществляется с​IRR​CDate​​ ItogF=ItogF+ F.​​ заметить, программировать в​

​Cells(i, 2).Value = y​End Sub​ дате.Пример:​IsDate(100)​В VBA доступно множество​ группу операторов.​​ выберите тот, который​​ 4, 3) End​​ аргумент​​ VBA:​ и отредактировать текст​

​ в другую программу​ помощью окна Project​​Финансовые функции​​Функции преобразования типа данных​​Для отклонений используют =​​ самом известном табличном​ (значение y записывается​Обратите внимание, что строка​Year(«29/01/2015»)​возвращает​ встроенных функций, которые​Основные математические операторы VBA​​ хотите запустить.​​ Sub​​i​​Откройте рабочую книгу Excel​ макроса на VBA.​

VBA процедура «Function»

​ — запись останавливается.​​ Explorer в левом​​MIRR​CDbl​ (ItogF – ItogP)​ процессоре Microsoft не​

​ в ячейку с​ «’Наш код» будет​

​возвращает значение 2015.​​False​​ могут быть использованы​ перечислены в таблице​​Нажмите​​VBA процедуру​передан по значению.​ и запустите редактор​

  • ​Чтобы не запоминать сочетание​Макрорекордер может записать только​ верхнем углу редактора​​Финансовые функции​​Функции преобразования типа данных​
  • ​ / ItogP *​ так уж сложно.​ координатами (i,2))​ выделена другим цветом​​Данный список включает в​​.​ при написании кода.​ ниже.​Выполнить​Function​​ После выхода из​​ VBA (нажмите для​

​ клавиш для запуска​ те действия, для​

Пример VBA процедуры «Function»: Выполняем математическую операцию с 3 числами

​ (если его не​NPer​​CDec​​ 100, если расчет​ Особенно, если научиться​​i = i +​​ (зеленым). Причина в​ себя только избранные​IsError​ Ниже перечислены некоторые​В правом столбце таблицы​​(Run)​​можно вызвать из​ процедуры​ этого​

​ макроса, лучше создать​ которых есть команды​ видно, нажмите CTRL+R).​Финансовые функции​Функции преобразования типа данных​ ведется в процентах,​ применять функции VBA.​

​ 1 (действует счетчик);​ апострофе, поставленном в​​ наиболее часто употребляемые​​Возвращает​ из наиболее часто​ указан приоритет операторов,​Чтобы выполнять процедуру​ рабочего листа Excel​Sub​​Alt+F11​​ кнопку и назначить​ меню или кнопки​​ Программные модули бывают​​NPV​CInt​ а в случае​ Всего в этом​​x1 = x1 +​​ начале строки, который​ встроенные функции Excel​True​

Вызов VBA процедуры «Function»

​ используемых:​ принятый по умолчанию​​Sub​​ таким же образом,​все сделанные с​), и затем нажмите​ ей нужный макрос.​ в Excel. Программист​ нескольких типов для​Финансовые функции​Функции преобразования типа данных​

Вызов VBA процедуры «Function» из другой процедуры

​ суммарной величины —​​ языке программирования, созданном​​ shag (аргумент изменяется​ обозначает, что далее​ Visual Basic. Исчерпывающий​, если заданное значение​Функция Действие​ при отсутствии скобок.​быстро и легко,​​ как любую другую​​i​F2​

​ Кнопка может быть​ же может написать​ разных ситуаций:​Pmt​CLgn​

Вызов VBA процедуры «Function» из рабочего листа

​ (ItogF – ItogP).​​ специально для написания​​ на величину шага);​ следует комментарий.​ список функций VBA,​ является ошибкой, или​Abs​ Добавляя в выражение​ можно назначить для​​ встроенную функцию Excel.​​изменения будут утрачены.​​.​​ нескольких типов:​ макрос, который делает​Обычные модули​Финансовые функции​

​Функции преобразования типа данных​

VBA процедура «Sub»

​Результаты опять же сразу​ приложений в «Эксель»​​Loop​​Теперь вы можете написать​ доступных для использования​False​Возвращает абсолютную величину заданного​

​ скобки, можно изменять​ неё комбинацию клавиш.​

VBA процедура «Sub»: Пример 1. Выравнивание по центру и изменение размера шрифта в выделенном диапазоне ячеек

​ Следовательно, созданную в​Sub AddToCells(ByRef i As​​В выпадающем списке в​​Кнопка на панели инструментов​ то, что Excel​- используются в​PPmt​CSgn​ записываются в соответствующие​ и Word, около​End Sub.​ любой код и​

​ в макросах Excel,​– если ошибкой​ числа.​ порядок выполнения операторов​ Для этого:​ предыдущем примере процедуру​

​ Integer) … End​​ верхней левой части​​ в Excel 2003​ никогда не умел​

​ большинстве случаев, когда​Финансовые функции​Функции преобразования типа данных​​ ячейки, поэтому нет​​ 160 функций. Их​​В результате запуска данного​​ создать для себя​​ можно найти на​​ не является.​Пример:​ VBA по своему​Нажмите​​Function​​ Sub​​ экрана выберите библиотеку​​ и старше​ (сортировку по цвету,​ речь идет о​PV​

VBA процедура «Sub»: Пример 2. Выравнивание по центру и применение полужирного начертания к шрифту в выделенном диапазоне ячеек

​CStr​ необходимости их присваивания​ можно разделить на​ макроса в «Эксель»​ новый инструмент в​ сайте Visual Basic​IsMissing​Abs(-20)​​ желанию.​​Alt+F8​–​

​В этом случае целочисленный​VBA​Откройте меню​ например или что-то​ макросах. Для создания​

Вызов процедуры «Sub» в Excel VBA

Вызов VBA процедуры «Sub» из другой процедуры

​Финансовые функции​​Функции преобразования типа данных​​ переменным.​ несколько больших групп.​ получаем два столбца,​​ VBA Excel (примеры​​ Developer Center.​​В качестве аргумента функции​​возвращает значение 20;​Оператор Действие Приоритет​.​SumMinus​

​ аргумент​.​

​Сервис — Настройка​​ подобное).​​ такого модуля выберите​Rate​CVar​Перед запуском созданной программы,​

​ Это:​ в первом из​ программ см. далее).​

Вызов VBA процедуры «Sub» из рабочего листа

​Урок подготовлен для Вас​​ передаётся имя необязательного​​Abs(20)​(1 — высший;​В появившемся списке макросов​можно вызвать, введя​i​Появится список встроенных классов​​(Tools — Customize)​​Если во время записи​​ в меню​​Финансовые функции​Функции преобразования типа данных​​ требуется сохранить рабочую​​Математические функции. Применив их​ которых записаны значения​​ Конечно, тем, кто​​ командой сайта office-guru.ru​ аргумента процедуры.​возвращает значение 20.​ 5 — низший)​ выберите тот, которому​ в ячейку рабочего​​передан по ссылке.​​ и функций VBA.​и перейдите на​ макроса макрорекордером вы​​Insert — Module​​SLN​CVDate​ книгу, например, под​ к аргументу, получают​​ для x, а​​ знаком с азами​Источник: http://www.excelfunctions.net/VBA-Operators-And-Functions.html​IsMissing​

​Chr​^​​ хотите назначить сочетание​​ листа вот такое​ После выхода из​

  • ​ Кликните мышью по​​ вкладку​​ ошиблись — ошибка​​. В появившееся окно​​Финансовые функции​Функции преобразования типа данных​​ названием «Отчет1.xls».​​ значение косинуса, натурального​
  • ​ во втором —​ Visual Basic, будет​Перевел: Антон Андронов​
  • ​возвращает​​Возвращает символ ANSI, соответствующий​​Оператор возведения в степень​

​ клавиш.​​ выражение:​​ процедуры​ имени функции, чтобы​Команды (Commands)​ будет записана. Однако​

  • ​ нового пустого модуля​​SYD​​Choose​
  • ​Клавишу «Создать отчетную таблицу»​ логарифма, целой части​ для y.​ намного проще. Однако​
  • ​Автор: Антон Андронов​​True​​ числовому значению параметра.​1​Нажмите​
  • ​=SumMinus(10, 5, 2)​​Sub​​ внизу окна отобразилось​. В категории​​ смело можете давить​​ можно вводить команды​

​Финансовые функции​​Функции загрузки данных​ требуется нажать всего​ и пр.​Затем по ним строится​ даже те, кто​​Немногие знают, что первая​​, если для рассматриваемого​Пример:​*​Параметры​Редактор VBA понимает, что​все сделанные с​ её краткое описание.​

Область действия процедуры VBA

​Макросы​ на кнопку отмены​ на VBA, набирая​Format​IIf​​ 1 раз после​​Финансовые функции. Благодаря их​​ график способом, стандартным​​ их не имеет,​ версия популярного продукта​ аргумента процедуры не​Chr(10)​

​Оператор умножения​(Options) и в​ перед ним процедура​ ​i​ Нажатие​​легко найти веселый​​ последнего действия (Undo)​ их с клавиатуры​Функции форматирования​Функции загрузки данных​
​ ввода заголовочной информации.​ наличию и используя​ для «Эксель».​ ​ при желании смогут​ Microsoft Excel появилась​​ передано значение.​​возвращает перенос строки;​2​ появившемся диалоговом окне​Sub​изменения будут сохранены​F1​ желтый «колобок» -​ — во время​

​ или копируя их​FormatCurrency​InputBox​​ Следует знать и​​ программирование в Excel,​​Для реализации циклов в​​ освоиться достаточно быстро.​ в 1985 году.​IsNumeric​Chr(97)​​/​​ введите сочетание клавиш.​, когда встречает группу​ в переменной, которая​откроет страницу онлайн-справки​Настраиваемую кнопку​ записи макроса макрорекордером​ из другого модуля,​​Функции форматирования​​Функции загрузки данных​

Ранний выход из VBA процедур «Function» и «Sub»

​ другие правила. В​ можно получать эффективные​​ VBA Excel 2010,​​За таким названием скрываются​​ С тех пор​​Возвращает​возвращает символ​Оператор деления​Нажмите​​ команд, заключённую между​​ была передана процедуре​​ по этой функции.​​(Custom button)​ она не просто​ с этого сайта​​FormatDateTime​​LoadPicture​ частности, кнопка «Добавить​ инструменты для ведения​ как и в​ программы, написанные на​ он пережил несколько​True​a​2​ОК​ вот такими открывающим​Sub​Кроме того, полный список​

​:​ возрвращает Вас в​ или еще откуда​Функции форматирования​

​Функции загрузки данных​ строку» должна нажиматься​ бухгалтерского учета и​​ других версиях, наряду​​ языке Visual Basic​​ модификаций и востребован​​, если заданное значение​.​​​​и закройте диалоговое​ и закрывающим операторами:​.​

​ встроенных функций VBA​Перетащите ее к себе​
​ предыдущее состояние, но​
​ нибудь:​

​FormatNumber​

office-guru.ru

Операторы и встроенные функции VBA

Операторы Excel VBA

​LoadResData​ каждый раз после​ осуществления финансовых расчетов.​ с уже приведенной​ for Application. Таким​ у миллионов пользователей​ может быть рассмотрено​Date​Оператор деления без остатка​ окно​

Математические операторы

​Sub … End​Помните, что аргументы в​ с примерами можно​

​ на панель инструментов​ и стирает последнюю​Модуль Эта книга​Функции форматирования​Функции загрузки данных​ ввода в таблицу​Функции обработки массивов. К​ конструкцией Do While​ образом, программирование в​

​ по всему миру.​
​ как число, в​Возвращает текущую системную дату.​

​ – возвращает результат​ ​Макрос​ ​ Sub​
​ VBA по умолчанию​ ​ найти на сайте​ ​ и затем щелкните​
​ записанную команду на​ ​- также виден​ ​FormatPercent​
​LoadResPicture​ ​ значений по каждому​ ним относятся Array,​ используется For.​ Excel — это​​ При этом многие​​ противном случае возвращает​​DateAdd​ ​ деления двух чисел​
​(Macro).​ ​Рассмотрим пример простой VBA​ передаются по ссылке.​ Visual Basic Developer​ по ней правой​​ VBA.​​ в левом верхнем​​Функции форматирования​​Функции загрузки данных​ ​ виду деятельности. После​
​ IsArray; LBound; UBound.​ ​Рассмотрим программу, которая создаст​ ​ создание макросов с​
​ работают лишь с​ ​False​ ​Добавляет определённый временной интервал​

Строковые операторы

​ без остатка. Например,​Внимание:​ процедуры​​ Иначе говоря, если​​ Centre.​

​ кнопкой мыши. В​

​Чтобы включить запись необходимо:​ ​ углу редактора Visual​ObjPtr​​LoadResString​​ занесения всех данных​​Функции VBA Excel для​​ столбец. В каждой​

Операторы сравнения

​ нужным кодом. Благодаря​ малой толикой возможностей​.​ к заданной дате.​74​​Назначая сочетание клавиш​​Sub​ не использованы ключевые​В Excel Visual Basic​ контекстом меню можно​

​в Excel 2003 и​

​ Basic в окне,​ ​Функции работы с указателями​
​Функции загрузки данных​ ​ требуется нажать кнопку​
​ строки. Это достаточно​
​ его ячейке будут​ ​ этой возможности табличный​
​ этого табличного процессора​
​Left​ ​ Синтаксис функции:​

Логические операторы

​возвратит результат​ для макроса, убедитесь,​, задача которой –​​ слова​​ набор команд, выполняющий​ назначить кнопке макрос,​ старше — выбрать​ которое называется Project​

​StrPtr​

​MsgBox​ ​ «Закончить» и затем​​ многочисленная группа. В​​ записаны квадраты номера​​ процессор Microsoft саморазвивается,​​ и даже не​​Возвращает заданное количество символов​​DateAdd(​​1​​ что оно не​​ изменить форматирование выделенного​​ByVal​​ определённую задачу, помещается​​ выбрать другой значок​ в меню​​ Explorer. В этот​​Функции работы с указателями​
​Функции загрузки данных​ ​ переключиться в окно​​ нее входят, например,​​ соответствующей строки. Использование​​ подстраиваясь под требования​​ догадываются, как им​​ от начала переданной​​интервал​​3​​ используется, как стандартное​​ диапазона ячеек. В​​или​​ в процедуру​​ и имя:​​Сервис — Макрос -​​ модуль обычно записываются​​VarPtr​​CurDir​​ «Эксель».​​ функции Space для​​ конструкции For позволит​​ конкретного пользователя. Разобравшись​
​ могло бы облегчить​ ​ строки. Синтаксис функции​​,​​Mod​​ в Excel (например,​​ ячейках устанавливается выравнивание​​ByRef​​Function​​Кнопка на панели быстрого​​ Начать запись​​ макросы, которые должны​​Функции работы с указателями​​Функции работы с файлами​​Теперь вы знаете, как​​ создания строки с​​ записать ее очень​​ с тем, как​​ жизнь умение программирования​

​ вот такой:​число​Оператор модуля (остатка) –​Ctrl+C​ по центру (и​, то аргумент будет​(Функция) или​ доступа в Excel​

Встроенные функции

​(Tools — Macro -​ выполнятся при наступлении​Всем нам приходится -​Dir​ решать задачи для​ числом пробелов, равных​ коротко, без использования​

​ создавать модули для​

​ в Excel.​ ​Left(​,​

​ возвращает остаток от​

  • ​). Если выбрать уже​​ по вертикали, и​
  • ​ передан по ссылке.​​Sub​
​ 2007 и новее​ ​ Record New Macro)​ каких-либо событий в​

​ кому реже, кому​

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

​(Подпрограмма). Главное отличие​​Щелкните правой кнопкой мыши​​в Excel 2007 и​​ книге (открытие или​​ чаще - повторять​​EOF​​ макросов. Умение применять​

​ Asc для перевода​​Сначала нужно создать макрос,​​ приступать к рассмотрению​ посредством языка программирования​,​​)​​ Например,​ то оно будет​​ размер шрифта изменяется​​ изучение процедур​

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

​ одни и те​

​Функции работы с файлами​ ​ vba excel (примеры​
​ символов в код​ ​ как описано выше.​
​ конкретных примеров программ​ ​ Visual Basic for​
​длина​ ​Где аргумент​
​8 Mod 3​ ​ переназначено макросу, и​
​ на заданный пользователем:​ ​Function​
​Function​ ​ доступа в левом​
​ кнопку​ ​ файла и т.п.):​
​ же действия и​ ​FileAttr​
​ программ см. выше)​ ​ ANSI. Все они​

​ Далее записываем сам​

  • ​ VBA Excel. Лучше​​ Application, который изначально​)​интервал​возвратит результат​
  • ​ в результате пользователь​​Sub Format_Centered_And_Sized(Optional iFontSize​и​и​ верхнем углу окна​
​Запись макроса (Record macro)​ ​Модуль листа​ операции в Excel.​Функции работы с файлами​

​ может понадобиться и​

  • ​ имеют широкое применение​​ код. Считаем, что​ всего начать с​ встроен в самый​где​
  • ​определяет тип временного​​2​ может запустить выполнение​ As Integer =​Sub​
​Sub​ ​ Excel и выберите​на вкладке​- доступен через​

​ Любая офисная работа​​FileDateTime​​ для работы в​

​ и позволяют работать​ ​ нас интересуют значения​ самых элементарных кодов.​ известный табличный процессор​

​строка​​ интервала, добавляемого к​​.​

​ макроса случайно.​ ​ 10) Selection.HorizontalAlignment =​более подробно, будет​состоит в том,​ команду​Разработчик (Developer)​ Project Explorer и​ предполагает некую «рутинную​Функции работы с файлами​

​ среде самого популярного​

  • ​ со строками в​ для 10 ячеек.​​Задача: написать программу, которая​
  • ​ от Microsoft.​– это исходная​ заданной​​4​

​В части 2 данного​​ xlCenter Selection.VerticalAlignment =​ полезным ещё раз​ что процедура​Настройка панели быстрого доступа​Затем необходимо настроить параметры​ через контекстное меню​ составляющую» — одни​

​FileLen​ ​ на данный момент​ «Эксель», создавая приложения,​

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

​ строка, а​ ​дате​​+​​ самоучителя обсуждалась тема​ xlCenter Selection.Font.Size =​​ взглянуть на особенности​​Function​ (Customise Quick Access​

​ записываемого макроса в​

  • ​ листа, т.е. правой​​ и те же​​Функции работы с файлами​​ текстового редактора «Ворд».​
  • ​ значительно облегчающие работу​​ образом.​​ содержимое одной ячейки​​ относят сравнительную легкость​
​длина​ ​в количестве, указанном​​Оператор сложения​​ области действия переменных​ iFontSize End Sub​​ и отличия этих​​возвращает результат, процедура​ Toolbar)​
​ окне​ ​ кнопкой мыши по​ еженедельные отчеты, одни​FreeFile​​ В частности, можно​​ с этими таблицами.​​For i = 1​​ и затем записывать​ освоения. Как показывает​– количество возвращаемых​
​ в аргументе​ ​5​​ и констант и​​Данная процедура​ двух типов процедур.​Sub​:​​Запись макроса​​ ярлычку листа -​
​ и те же​ ​Функции работы с файлами​ путем записи, как​Функции преобразования типа данных.​ to 10 Next​

​ в другую.​​ практика, азами VBA​​ символов, считая от​​число​​—​

​ роль ключевых слов​​Sub​​ Далее приведены краткие​– нет.​​Затем в открывшемся окне​​:​ команда​ действия по обработке​

​GetAttr​

  • ​ показано в самом​​ Например, CVar возвращает​
  • ​Команда переводится на «человеческий»​​Для этого:​
​ могут овладеть даже​ ​ начала строки.​.​

​Оператор вычитания​​Public​​выполняет действия, но​

​ обсуждения процедур VBA​ ​Поэтому, если требуется выполнить​ выберите категорию​Имя макроса​

​Исходный текст (View Source)​​ поступивших данных, заполнение​​Функции работы с файлами​

​ начале статьи, или​ ​ значение аргумента Expression,​ язык, как «Повторять​открывают вкладку «Вид»;​

​ пользователи, которые не​​Пример:​​Аргумент​​5​​и​​ не возвращает результат.​​Function​

​ действия и получить​​Макросы​​- подойдет любое​. Сюда записывают макросы,​​ однообразных таблиц или​​Input​ через написание кода​​ преобразовав его в​​ от 1 до​переходят на пиктограмму «Макросы»;​

​ имеют навыков профессионального​

  • ​Left(«абвгдежзиклмн», 4)​​интервал​
  • ​Основной строковый оператор в​​Private​
​В этом примере также​ ​и​ какой-то результат (например,​и при помощи​​ имя на русском​​ которые должны выполняться​
​ бланков и т.д.​ ​Функции работы с файлами​ создавать кнопки меню,​
​ тип данных Variant.​ ​ 10 с шагом​жмут на «Запись макроса»;​ программирования. К особенностям​

​возвращает строку «абвг»;​​может принимать одно​​ Excel VBA –​​. Эти ключевые слова​​ использован необязательный (Optional)​

​Sub​​ просуммировать несколько чисел),​​ кнопки​ или английском языке.​​ при наступлении определенных​​ Использование макросов и​Loc​ благодаря которым многие​Функции работы с датами.​

​ один».​

  • ​заполняют открывшуюся форму.​​ VBA относится выполнение​
  • ​Left(«абвгдежзиклмн», 1)​​ из следующих значений:​
​ это оператор конкатенации ​ ​ так же можно​ аргумент​и показаны простые​

​ то обычно используется​​Добавить (Add)​​ Имя должно начинаться​

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

​ Они значительно расширяют​

  • ​Если ставится задача получить​​Для простоты в поле​
  • ​ скрипта в среде​​возвращает строку «а».​
​Интервал Значение​ ​&​
​ использовать применительно к​ ​iFontSize​ примеры.​

​ процедура​​перенесите выбранный макрос​ с буквы и​ (изменение данных в​ автоматизировать эти операции,​LOF​ можно будет осуществлять​ стандартные возможности «Эксель».​ столбец с квадратами,​

​ «Имя макроса» оставляют​ ​ офисных приложений.​Len​yyyy​​(слияние):​​ VBA процедурам:​

​. Если аргумент​Редактор VBA распознаёт процедуру​Function​ в правую половину​ не содержать пробелов​ ячейках, пересчет листа,​ перекладывая монотонную однообразную​Функции работы с файлами​ нажатием дежурных клавиш​ Так, функция WeekdayName​ например, всех нечетных​

​ «Макрос1», а в​Недостатком программы являются проблемы,​
​Возвращает количество символов в​
​год​

​Оператор Действие​

office-guru.ru

VBA Excel: примеры программ. Макросы в Excel

​Public Sub AddToCells(i As​iFontSize​Function​, а для того,​ окна, т.е. на​ и знаков препинания.​ копирование или удаление​ работу на плечи​Seek​ или через вкладку​ возвращает название (полное​ чисел из диапазона​ поле «Сочетание клавиш»​ связанные с совместимостью​ строке.​q​&​ Integer) … End​

VBA Excel примеры программ

Что такое VBA

​не передан процедуре​, когда встречает группу​ чтобы просто выполнить​ панель быстрого доступа:​Сочетание клавиш​ листа и т.д.)​ Excel. Другим поводом​

​Функции работы с файлами​ «Вид» и пиктограмму​ или частичное) дня​ от 1 до​ вставляют, например, hh​ различных версий. Они​Пример:​квартал​Оператор конкатенации. К примеру,​ Sub​Sub​

​ команд, заключённую между​ какие-то действия (например,​Кнопка на листе​- будет потом​Обычный макрос, введенный в​ для использования макросов​CallByName​ «Макросы».​ недели по его​ 11, то пишем:​ (это значит, что​ обусловлены тем, что​Len(«абвгдеж»)​m​ выражение​Если перед объявлением процедуры​, то его значение​ вот такими открывающим​ изменить форматирование группы​Этот способ подходит для​ использоваться для быстрого​ стандартный модуль выглядит​

функции VBA

Объекты, коллекции, свойства и методы

​ в вашей работе​Функции обработки системных параметров​Автор: Наира​ номеру. Еще более​For i = 1​ запустить программку можно​ код программы VBA​возвращает число 7.​месяц​«A» & «B»​ стоит ключевое слово​ по умолчанию принимается​ и закрывающим операторами:​

​ ячеек), нужно выбрать​ любой версии Excel.​ запуска макроса. Если​ примерно так:​ может стать необходимость​Command​Функция Категория​ полезной является Timer.​ to 10 step​ будет блиц-командой «Ctrl+h»).​

​ обращается к функциональным​Month​y​возвратит результат​Public​ равным 10. Однако​Function … End​ процедуру​

​ Мы добавим кнопку​ забудете сочетание или​Давайте разберем приведенный выше​ добавить в Microsoft​Функции обработки системных параметров​Abs​

​ Он выдает число​ 1 Next.​ Нажимают Enter.​ возможностям, которые присутствуют​Возвращает целое число, соответствующее​день года​AB​, то данная процедура​ же, если аргумент​ Function​Sub​ запуска макроса прямо​ вообще его не​ в качестве примера​ Excel недостающие, но​

​CVErr​Математические функции​ секунд, которые прошли​Здесь step — шаг.​

циклы VBA

Как начать

​Теперь, когда уже запущена​ в новой версии​ месяцу в заданной​d​.​ будет доступна для​

​iFontSize​Как упоминалось ранее, процедура​.​ на рабочий лист,​ введете, то макрос​

  • ​ макрос​ нужные вам функции.​Функции обработки системных параметров​Atn​ с полуночи до​
  • ​ В данном случае​
  • ​ запись макроса, производят​ продукта, но отсутствуют​ дате.​
  • ​день​Операторы сравнения используются для​

​ всех модулей в​

​ передается процедуре​

​Function​

​При помощи аргументов процедурам​

​ как графический объект.​ можно будет запустить​Zamena​ Например функцию сборки​DoEvents​Математические функции​ конкретного момента дня.​ он равен двум.​

​ копирование содержимого какой-либо​ в старой. Также​Пример:​w​ сравнения двух чисел​ данном проекте VBA.​Sub​в VBA (в​ VBA могут быть​ Для этого:​ через меню​:​ данных с разных​Функции обработки системных параметров​

Макросы в Excel

​Cos​Функции для преобразования числового​ По умолчанию отсутствие​ ячейки в другую.​ к минусам относят​Month(«29/01/2015»)​день недели​ или строк и​Private Sub AddToCells(i As​, то в выделенном​ отличие от​ переданы различные данные.​В Excel 2003 и​Сервис — Макрос -​Любой макрос должен начинаться​ листов на один​Environ​Математические функции​ аргумента в разные​ этого слова в​

Пример 1

​ Возвращаются на исходную​ и чрезмерно высокую​возвращает значение 1.​ww​ возвращают логическое значение​

​ Integer) … End​

  • ​ диапазоне ячеек будет​
  • ​Sub​
  • ​ Список аргументов указывается​
  • ​ старше — откройте​

​ Макросы — Выполнить​ с оператора​ итоговый лист, разнесения​Функции обработки системных параметров​Exp​ системы счисления. Например,​ цикле означает, что​ пиктограмму. Нажимают на​ открытость кода для​

​Mid​неделя​ типа​ Sub​ установлен размер шрифта,​), возвращает значение. Для​ при объявлении процедуры.​ панель инструментов​(Tools — Macro -​

​Sub​

  • ​ данных обратно, вывод​Erl​
  • ​Математические функции​ Oct выдает в​
  • ​ шаг единичный.​ «Запись макроса». Это​ изменения посторонним лицом.​

​Возвращает заданное количество символов​h​Boolean​Если перед объявлением процедуры​

​ заданный пользователем.​ возвращаемых значений действуют​ К примеру, процедура​Формы​ Macros — Run)​, за которым идет​ суммы прописью и​Функции обработки системных параметров​Fix​ восьмеричное представление числа.​Полученные результаты нужно сохранять​ действие означает завершение​

​ Тем не менее​ из середины переданной​час​(True или False).​ стоит ключевое слово​Следующая процедура похожа на​ следующие правила:​Sub​через меню​или с помощью​ имя макроса и​ т.д.​

​Error​Математические функции​Функции форматирования. Важнейшей из​ в ячейки с​ программки.​ Microsoft Office, а​ строки. Синтаксис функции:​

Пример 2

​n​ Основные операторы сравнения​Private​

​ только что рассмотренную,​Тип данных возвращаемого значения​в VBA добавляет​Вид — Панели инструментов​ кнопки​ список аргументов (входных​Макрос​Функции обработки системных параметров​Int​ них является Format.​

​ номером (i,1). Тогда​Далее:​ также IBM Lotus​Mid(​минута​ Excel VBA перечислены​, то данная процедура​ но на этот​ должен быть объявлен​

​ заданное целое число​ — Формы (View​Макросы (Macros)​ значений) в скобках.​- это запрограммированная​GetAllSettings​Математические функции​

​ Она возвращает значение​

​ при каждом запуске​

​вновь переходят на строку​

​ Symphony позволяют пользователю​

​строка​

​s​ в этой таблице:​ будет доступна только​ раз, вместо изменения​ в заголовке процедуры​

​ (Integer) в каждую​ — Toolbars -​

​на вкладке​ Если аргументов нет,​ последовательность действий (программа,​Функции обработки системных параметров​

​IsNumeric​ типа Variant с​ цикла с увеличением​ «Макросы»;​

​ применять шифрование начального​,​

​секунда​Оператор Действие​ для текущего модуля.​

​ размера, применяется полужирное​

​Function​

​ ячейку в выделенном​ Forms)​Разработчик (Developer)​ то скобки надо​ процедура), записанная на​GetSetting​Математические функции​ выражением, отформатированным согласно​

​ i на величину​в списке выбирают «Макрос​ кода и установку​

программирование в Excel

Пример 3

​начало​Пример:​=​ Её нельзя будет​ начертание шрифта в​.​ диапазоне. Передать процедуре​

​В Excel 2007 и​или нажав ALT+F8.​ оставить пустыми.​ языке программирования Visual​Функции обработки системных параметров​Log​ инструкциям, которые заданы​ шага автоматически будет​ 1»;​

​ пароля для его​,​DateAdd(«d», 32, «01/01/2015»)​Равно​ вызвать, находясь в​ выделенном диапазоне ячеек.​Переменная, которая содержит возвращаемое​ это число можно​

​ новее — откройте​Сохранить в…​

​Любой макрос должен заканчиваться​ Basic for Applications​IMEStatus​Математические функции​ в описании формата.​

​ расти и номер​нажимают «Выполнить» (то же​ просмотра.​длина​добавляет 32 дня​<>​

​ любом другом модуле​ Это пример процедуры​ значение, должна быть​

​ при помощи аргумента,​ выпадающий список​- здесь задается​ оператором​ (VBA). Мы можем​Функции обработки системных параметров​Rnd​

​и пр.​ у строки. Таким​ действие запускается начатием​Именно с этими понятиями​)​ к дате 01/01/2015​Не равно​ или из рабочей​Sub​ названа так же,​ вот так:​

​Вставить (Insert)​ место, куда будет​

​End Sub​

​ запускать макрос сколько​IsEmpty​Математические функции​Изучение свойств этих функций​ образом, произойдет оптимизация​ сочетания клавиш «Ctrl+hh»).​

​ нужно разобраться тем,​где​ и, таким образом,​Меньше​ книги Excel.​

​, которой не передаются​ как и процедура​Sub AddToCells(i As​на вкладке​

​ сохранен текст макроса,​

​.​ угодно раз, заставляя​Функции обработки системных параметров​Round​ и их применение​ кода.​В результате происходит действие,​ кто собирается работать​строка​ возвращает дату 02/02/2015.​>​

примеры макросов VBA Excel

Пример 4

​Помните о том, что​ никакие аргументы:​Function​ Integer) … End​Разработчик (Developer)​ т.е. набор команд​Все, что находится между​ Excel выполнять последовательность​IsError​Математические функции​ позволит значительно расширить​В целом код будет​ которое было осуществлено​ в среде VBA.​– это исходная​DateAdd(«ww», 36, «01/01/2015»)​Больше​

​ если перед объявлением​Sub Format_Centered_And_Bold() Selection.HorizontalAlignment​. Эту переменную не​ Sub​ ​ на VBA из​

​Sub​

​ любых нужных нам​

​Функции обработки системных параметров​

​Sgn​ сферу применения «Эксель».​ выглядеть, как:​ в процессе записи​ Прежде всего необходимо​ строка,​

​добавляет 36 недель​

​Меньше либо равно​ VBA процедуры​ = xlCenter Selection.VerticalAlignment​ нужно объявлять отдельно,​Имейте в виду, что​

​Выберите объект​ которых и состоит​

​и​ действий, которые нам​

​IsMissing​

​Математические функции​

​Попробуем перейти к решению​Sub program()​ макроса.​ понять, что такое​

Функции VBA

​начало​ к дате 01/01/2015​>=​Function​ = xlCenter Selection.Font.Bold​ так как она​ наличие аргументов для​Кнопка (Button):​ макрос.:​End Sub​ не хочется выполнять​Функции обработки системных параметров​Sin​ более сложных задач.​For i = 1​Имеет смысл увидеть, как​

  • ​ объект. В Excel​– позиция начала​ и возвращает дату​Больше либо равно​или​
  • ​ = True End​ всегда существует как​ процедур​Затем нарисуйте кнопку на​Эта книга​- тело макроса,​ вручную.​
  • ​IsNull​Математические функции​ Например:​
  • ​ To 10 Step​ выглядит код. Для​ в этом качестве​ извлекаемой строки,​ 09/09/2015.​Логические операторы, как и​Sub​ Sub​ неотъемлемая часть процедуры​Function​ листе, удерживая левую​- макрос сохраняется​ т.е. команды, которые​В принципе, существует великое​Функции обработки системных параметров​Sqr​Дан бумажный документ отчета​
  • ​ 1 (можно записать​ этого вновь переходят​ выступают лист, книга,​длина​DateDiff​
  • ​ операторы сравнения, возвращают​ключевое слово не​Чтобы вызвать VBA процедуру​Function​и​ кнопку мыши. Автоматически​ в модуль текущей​ будут выполняться при​ множество языков программирования​Shell​Математические функции​ фактического уровня издержек​ просто For i​
  • ​ на строку «Макросы»​ ячейка и диапазон.​– количество символов,​Вычисляет количество определённых временных​ логическое значение типа​
  • ​ вставлено, то по​Sub​.​Sub​ появится окно, где​ книги и, как​ запуске макроса. В​
  • ​ (Pascal, Fortran, C++,​

​Функции обработки системных параметров​Tan​ предприятия. Требуется:​ = 1 To​

Пример 5

​ и нажимают «Изменить»​ Данные объекты обладают​ которые требуется извлечь.​

​ интервалов между двумя​Boolean​ умолчанию для процедуры​

  • ​из другой VBA​Это отлично проиллюстрировано в​в VBA не​
  • ​ нужно выбрать макрос,​ следствие, будет выполнятся​ данном случае макрос​ C#, Java, ASP,​Switch​Математические функции​разработать его шаблонную часть​

​ 10)​ или «Войти». В​

Создание шаблона

​ специальной иерархией, т.е.​Пример:​ заданными датами.​(True или False).​ устанавливается свойство​ процедуры, нужно записать​ следующем примере.​ является обязательным. Для​ который должен запускаться​ только пока эта​ выделяет ячейку заливает​ PHP…), но для​Функции обработки системных параметров​Array​ посредством табличного процессора​Cells(i, 1).Value = i​ результате оказываются в​ подчиняются друг другу.​

Переменные

​Mid(«абвгдежзиклмн», 4, 5)​Пример:​ Основные логические операторы​Public​ ключевое слово​

  • ​Ниже приведён пример кода​ некоторых процедур аргументы​
  • ​ при щелчке по​ книга открыта в​ выделенных диапазон (Selection)​
  • ​ всех программ пакета​QBColor​Функции обработки массивов​
  • ​ «Эксель»;​ ^ 2 (т.е.​ среде VBA. Собственно,​

​Главным из них является​возвращает строку «гдежз»;​DateDiff(«d», «01/01/2015», «02/02/2015»)​ Excel VBA перечислены​(то есть она​Call​ VBA процедуры​ не нужны.​

макросы в Excel

Решение задачи с использованием программирования на VBA

​ нарисованной кнопке.​ Excel​ желтым цветом (код​ Microsoft Office стандартом​Функции обработки цвета​IsArray​составить программу VBA, которая​ в ячейку (i,1)​ сам код макроса​

​ Application, соответствующий самой​Mid(«абвгдежзиклмн», 10, 2)​вычисляет количество дней​ в таблице ниже:​

​ будет доступна везде​, имя процедуры​Function​Процедуры VBA могут иметь​Создание пользовательских функций или,​

​Новая книга​ = 6) и​ является именно встроенный​RGB​Функции обработки массивов​ будет запрашивать исходные​ записывается значение квадрата​ находится между строками​

​ программе Excel. Затем​возвращает строку «кл».​ между датами 01/01/2015​Оператор Действие​ в данном проекте​

​Sub​, которая получает три​ необязательные аргументы. Это​ как их иногда​

​- макрос сохраняется​ затем проходит в​ язык VBA. Команды​Функции обработки цвета​LBound​ данные для ее​ i)​ Sub Макрос1() и​ следуют Workbooks, Worksheets,​Minute​ и 02/02/2015, возвращает​And​ VBA). В этом​и далее в​ аргумента типа​ такие аргументы, которые​ еще называют, UDF-функций​

VBA Excel 2010

​ в шаблон, на​ цикле по всем​ этого языка понимает​Date​Функции обработки массивов​ заполнения, осуществлять необходимые​Next (в некотором смысле​ End Sub.​ а также Range.​Возвращает целое число, соответствующее​ результат 32.​Операция конъюнкции, логический оператор​ состоит отличие от​ скобках аргументы процедуры.​Double​ пользователь может указать,​ (User Defined Functions)​ основе которого создается​ ячейкам, заменяя формулы​ любое офисное приложение,​Функции работы с датами​UBound​ расчеты и заполнять​ играет роль счетчика​

​Если копирование было выполнено,​

fb.ru

Список всех функций

​ Например, для обращения​

​ количеству минут в​ ​DateDiff(«ww», «01/01/2015», «03/03/2016»)​
​И​ ​ объявления переменных, которые​
​ Это показано в​ ​(числа с плавающей​
​ если захочет, а​ ​ принципиально не отличается​
​ любая новая пустая​ ​ на значения. В​
​ будь то Excel,​ ​DateAdd​
​Функции обработки массивов​ ​ ими соответствующие ячейки​
​ и означает еще​ ​ например, из ячейки​
​ к ячейке A1​ ​ заданном времени.Пример:​
​вычисляет количество недель​ ​. Например, выражение​
​ по умолчанию бывают​ ​ примере ниже:​
​ точкой двойной точности).​ ​ если они пропущены,​
​ от создания макроса​ ​ книга в Excel,​
​ конце выводится окно​ ​ Word, Outlook или​
​Функции работы с датами​ ​Asc​
​ шаблона.​ ​ один запуск цикла)​
​ А1 в ячейку​ ​ на конкретном листе​
​Minute(«22:45:15»)​ ​ между датами 01/01/2015​
​A And B​ ​Private​
​Sub main() Call​ ​ В результате процедура​
​ то процедура использует​ ​ в обычном программном​
​ т.е. макрос будет​ ​ сообщения (MsgBox).​
​ Access.​ ​DateDiff​
​Функции обработки строк​ ​Рассмотрим один из вариантов​
​End Sub.​ ​ C1, то одна​
​ следует указать путь​ ​возвращает значение 45.​
​ и 03/03/2016, возвращает​ ​возвратит​
​.​ ​ Format_Centered_And_Sized(20) End Sub​
​ возвращает ещё одно​ ​ для них заданные​
​ модуле. Разница только​ ​ содержаться во всех​
​С ходу ясно, что​ ​Для ввода команд и​
​Функции работы с датами​ ​Chr​
​ решения.​ ​Если все сделано правильно,​
​ из строк кода​ ​ с учетом иерархии.​
​Now​ ​ результат 61.​
​True​ ​Если нужно завершить выполнение​
​Если процедура​ ​ число типа​
​ по умолчанию значения.​ ​ в том, что​
​ новых книгах, создаваемых​ ​ вот так сразу,​
​ формирования программы, т.е.​ ​DatePart​
​Функции обработки строк​ ​Все действия осуществляются на​
​ в том числе​ ​ будет выглядеть, как​
​Что касается понятия «коллекция»,​ ​Возвращает текущую системную дату​
​Day​ ​, если​
​ VBA процедуры​ ​Format_Centered_And_Sized​
​Double​ ​Возвращаясь к предыдущему примеру,​
​ макрос выполняет последовательность​ ​ на данном компьютере​
​ без предварительной подготовки​ ​ создания макроса необходимо​
​Функции работы с датами​ ​Filter​
​ стандартном листе в​ ​ запись и запуск​
​ Range(“C1”).Select. В переводе​ ​ то это группа​
​ и время.​ ​Возвращает целое число, соответствующее​
​A​ ​Function​
​имеет более одного​ ​, равное сумме первых​
​ чтобы сделать целочисленный​ ​ действий с объектами​
​ начиная с текущего​ ​ и опыта в​
​ открыть специальное окно​ ​DateSerial​
​Функции обработки строк​ ​ Excel. Резервируются свободные​
​ макроса (см. инструкцию​ ​ это выглядит, как​
​ объектов того же​ ​Right​
​ дню месяца в​ ​и​
​или​ ​ аргумента, то они​
​ двух аргументов минус​ ​ аргумент функции необязательным,​
​ книги (ячейками, формулами​ ​ момента​
​ программировании вообще и​ ​ — редактор программ​
​Функции работы с датами​ ​InStr​
​ ячейки для внесения​ ​ выше), то при​
​ «Диапазон(“C1”).Выделить», иными словами​ ​ класса, которая в​
​Возвращает заданное количество символов​ ​ заданной дате.​
​B​ ​Sub​
​ должны быть разделены​ ​ третий аргумент:​
​ его нужно объявить​ ​ и значениями, листами,​
​Личная книга макросов​ ​ на VBA в​
​ на VBA, встроенный​ ​DateValue​
​Функции обработки строк​ ​ данных по месяцу,​
​ его вызове каждый​ ​ осуществляет переход в​
​ записи имеет вид​ ​ от конца переданной​
​Пример:​ ​оба равны​
​, не дожидаясь её​ ​ запятыми. Вот так:​
​Function SumMinus(dNum1 As​ ​ вот так:​
​ диаграммами и т.д.),​ ​- это специальная​
​ частности, сложновато будет​ ​ в Microsoft Excel.​
​Функции работы с датами​ ​InStrRev​
​ году, названию компании-потребителя,​ ​ раз будет получаться​
​ VBA Excel, в​ ​ ChartObjects. Ее отдельные​
​ строки. Синтаксис функции:​ ​Day(«29/01/2015»)​
​True​ ​ естественного финала, то​
​Sub main() Call​ ​ Double, dNum2 As​
​Sub AddToCells(Optional i​ ​ а пользовательская функция​
​ книга Excel с​ ​ сообразить какие именно​
​В старых версиях (Excel​ ​Day​
​Функции обработки строк​ ​ сумме издержек, их​
​ столбец заданного размера​ ​ ячейку С1.​
​ элементы также являются​ ​Right(​
​возвращает число 29.​ ​, в противном случае​
​ для этого существуют​ ​ Format_Centered_And_Sized(arg1, arg2, …)​
​ Double, dNum3 As​ ​ As Integer =​
​ — только с​ ​ именем​
​ команды и как​ ​ 2003 и старше)​
​Функции работы с датами​ ​Join​
​ уровня, товарооборота. Так​ ​ (в данном случае​
​Активную часть кода завершает​ ​ объектами.​
​строка​ ​Hour​
​ возвратит​ ​ операторы​
​ End Sub​ ​ Double) As Double​
​ 0)​ ​ теми значениями, которые​
​Personal.xls​ ​ надо вводить, чтобы​
​ для этого идем​ ​Hour​
​Функции обработки строк​ ​ как количество компаний​
​ состоящий из 10​ ​ команда ActiveSheet.Paste. Она​
​Следующее понятие — свойства.​ ​,​
​Возвращает целое число, соответствующее​ ​False​
​Exit Function​ ​Процедура​
​ SumMinus = dNum1​ ​В таком случае целочисленный​
​ мы передадим ей​ ​, которая используется как​
​ макрос автоматически выполнял​ ​ в меню​
​Функции работы с датами​ ​LCase​
​ (обществ), относительно которых​ ​ ячеек).​ означает запись содержания​
​ Они являются необходимой​ ​длина​ количеству часов в​
​.​ ​и​Sub​
​ + dNum2 -​ ​ аргумент​
​ как аргументы (исходные​ ​ хранилище макросов. Все​
​ все действия, которые,​ ​Сервис — Макрос -​
​IsDate​ ​Функции обработки строк​
​ составляется отчет, не​ ​В повседневной жизни сплошь​
​ выделенной ячейки (в​ ​ характеристикой любого объекта.​
​)​ ​ заданном времени.​
​Or​ ​Exit Sub​
​не может быть​ ​ dNum3 End Function​
​i​ ​ данные для расчета).​
​ макросы из​ ​ например, Вы делаете​
​ Редактор Visual Basic​ ​Функции работы с датами​
​Left​ ​ зафиксировано, ячейки для​
​ и рядом возникает​ ​ данном случае А1)​
​ Например, для Range​ ​Где​
​Пример:​ ​Операция дизъюнкции, логический оператор​
​. Применение этих операторов​ ​ введена непосредственно в​
​Эта очень простая VBA​ ​по умолчанию будет​
​Чтобы создать пользовательскую функцию​ ​Personal.xls​
​ для создания еженедельного​ ​(Toos — Macro -​
​Minute​ ​Функции обработки строк​
​ внесения значений по​ ​ необходимость принять то​
​ в выделенную ячейку​ ​ — это Value​
​строка​ ​Hour(«22:45:00»)​
​ИЛИ​ ​ показано ниже на​

excelworld.ru

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

Введение

​ ячейку листа Excel,​ процедура​ равен 0.​ для расчета, например,​загружаются в память​ отчета для руководства​ Visual Basic Editor)​Функции работы с датами​Len​ итогам и ФИО​ или иное решение​ С1.​ или Formula.​– это исходная​возвращает число 22.​. Например, выражение​ примере простой процедуры​ как это может​Function​Необязательных аргументов в процедуре​ налога на добавленную​ при старте Excel​ компании. Поэтому мы​.​Month​Функции обработки строк​ специалиста заранее не​ в зависимости от​Циклы VBA помогают создавать​Методы — это команды,​ строка, а​InStr​A Or B​Function​ быть сделано с​

​иллюстрирует, как данные​​ может быть несколько,​ стоимость (НДС) откроем​ и могут быть​ переходим ко второму​В новых версиях (Excel​Функции работы с датами​LTrim​ резервируют. Рабочему листу​ какого-то условия. Не​ различные макросы в​ показывающие, что требуется​длина​Принимает в качестве аргументов​

​возвратит​, в которой ожидается​ процедурой​ передаются процедуре через​ все они перечисляются​ редактор VBA, добавим​ запущены в любой​ способу создания макросов,​ 2007 и новее)​MonthName​Функции обработки строк​ присваивается новое название.​ обойтись без них​ Excel.​

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

​ сделать. При написании​– это количество​ целое число и​True​ получение положительного аргумента​Function​ аргументы. Можно увидеть,​

  • ​ в конце списка​ новый модуль через​ момент и в​ а именно…​​ для этого нужно​Функции работы с датами​ ​Mid​ Например, «Օтчет».​​ и в VBA​
  • ​Циклы VBA помогают создавать​ кода в VBA​ символов, которые надо​ две строки. Возвращает​​, если​​ для выполнения дальнейших​​, потому что процедура​ что тип данных,​ аргументов.​ меню​​ любой книге.​Макрорекордер​ сначала отобразить вкладку​​Now​​Функции обработки строк​Для написания программы автоматического​ Excel. Примеры программ,​ различные макросы. Предположим,​ их необходимо отделять​ извлечь, считая от​ позицию вхождения второй​​A​ ​ операций. Если процедуре​

    Excel vba функции​Sub​

​ возвращаемых процедурой, определён​Аргументы в VBA могут​Insert — Module​После включения записи и​- это небольшая​Разработчик (Developer)​Функции работы с датами​Partition​

Excel vba функции

​ заполнения шаблона, необходимо​ где дальнейший ход​ что имеется функция​ от объекта точкой.​ конца заданной строки.​ строки внутри первой,​или​ передано не положительное​не возвращает значение.​ как​ быть переданы процедуре​и введем туда​ выполнения действий, которые​ программа, встроенная в​. Выбираем​Second​Функции обработки строк​ выбрать обозначения. Они​ выполнения алгоритма выбирается,​ y=x + x2​ Например, как будет​

  • ​Пример:​​ начиная поиск с​B​ значение, то дальнейшие​ Однако, процедуры​Double​ двумя способами:​​ текст нашей функции:​​ необходимо записать, запись​ Excel, которая переводит​Файл — Параметры -​Функции работы с датами​Replace​ будут использоваться для​ а не предопределен​ + 3×3 –​ показано в дальнейшем,​Right(«абвгдежзиклмн», 4)​
    Excel vba функции
  • ​ позиции, заданной целым​​равны​ операции не могут​Sub​(об этом говорят​ByVal​Обратите внимание, что в​ можно остановить командой​ любое действие пользователя​ Настройка ленты (File​Time​Функции обработки строк​ переменных:​ изначально, чаще всего​
    Excel vba функции
  • ​ cos(x). Требуется создать​​ очень часто при​возвращает строку «клмн»;​ числом.​True​ быть выполнены, поэтому​, не имеющие аргументов​ слова​​– передача аргумента​​ отличие от макросов​Остановить запись​ на язык программирования​ — Options -​Функции работы с датами​Right​NN– номер текущей строки​ используют конструкцию If​
    Excel vba функции

​ макрос для получения​ программировании в «Эксель»​Right(«абвгдежзиклмн», 1)​

Excel vba функции

​Пример:​, и возвратит​ пользователю должно быть​​ и объявленные как​​As Double​

  • ​ по значению. Это​ функции имеют заголовок​​(Stop Recording)​​ VBA и записывает​ Customize Ribbon)​Timer​Функции обработки строк​ таблицы;​ …Then (для сложных​ ее графика. Сделать​
  • ​ используют команду Cells(1,1).Select.​возвращает строку «н».​​InStr(1, «Вот искомое слово»,​​False​
  • ​ показано сообщение об​​Public​​после списка аргументов).​​ значит, что процедуре​​Function​.​ получившуюся команду в​и включаем в​Функции работы с датами​RTrim​TP и TF –​ случаев) If …Then​ это можно только,​ Она означает, что​Second​ «слово»)​, если​ ошибке и процедура​(как будет показано​

​ Также данный пример​ передаётся только значение​вместо​Управление всеми доступными макросами​ программный модуль. Если​ правой части окна​TimeSerial​Функции обработки строк​ планируемый и фактический​ …END If.​ используя циклы VBA.​ необходимо выбрать ячейку​Возвращает целое число, соответствующее​возвращает число 13.​A​ должна быть тут​ далее), будут доступны​ показывает, как результат​ (то есть, копия​

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

​Sub​​ производится в окне,​ мы включим макрорекордер​ флажок​Функции работы с датами​Space​ товарооборот;​Рассмотрим конкретный случай. Предположим,​За начальное и конечное​ с координатами (1,1)​ количеству секунд в​InStr(14, «Вот искомое слово,​и​ же завершена:​ для пользователей рабочего​ процедуры​ аргумента), и, следовательно,​и непустой список​ которое можно открыть​ на запись, а​Разработчик (Developer)​TimeValue​Функции обработки строк​SF и SP –​ необходимо создать макрос​ значение аргумента функции​ т.е. A1.​ заданном времени.​ а вот еще​B​Function VAT_Amount(sVAT_Rate As​ листа. Таким образом,​Function​ любые изменения, сделанные​ аргументов (в нашем​ с помощью кнопки​

  • ​ затем начнем создавать​. Теперь на появившейся​Функции работы с датами​Spc​ фактическая и планируемая​ для «Эксель», чтобы​ берут x1=0 и​Вместе с ней нередко​
  • ​Пример:​ искомое слово», «слово»)​оба равны​ Single) As Single​ если рассмотренные выше​сохраняется в переменной​ с аргументом внутри​ случае это​Макросы (Macros)​ свой еженедельный отчет,​ вкладке нам будут​Weekday​
  • ​Функции обработки строк​ сумма издержек;​ в ячейку с​ x2=10. Кроме того,​ используется Selection.ClearContents. Ее​Second(«22:45:15»)​возвращает число 38.​False​ VAT_Amount = 0​ простые процедуры​ с именем, совпадающим​ процедуры, будут потеряны​Summa​на вкладке​ то макрорекордер начнет​

​ доступны основные инструменты​

  • ​Функции работы с датами​Split​IP и IF –​​ координатами (1,1) было​ необходимо ввести константу​ ​ выполнение означает очистку​возвращает значение 15.​
  • ​Примечание:​.​ If sVAT_Rate​​Sub​​ с именем процедуры.​​ при выходе из​

​). После ввода кода​Разработчик (Developer)​ записывать команды вслед​​ для работы с​​WeekdayName​

Excel vba функции

  • ​Функции обработки строк​​ планируемый и фактически​ записано:​ — значение для​ содержимого выбранной ячейки.​Sqr​Аргумент-число может быть​Not​
  • ​Обратите внимание, что перед​​вставлены в модуль​Если рассмотренная выше простая​ неё.​ наша функция становится​или — в​ за каждым нашим​ макросами, в том​Функции работы с датами​​Str​ уровень издержек.​ ​1, если аргумент положительный;​ шага изменения аргумента​​Прежде всего требуется создать​Возвращает квадратный корень числовой​​ не задан, в​​Операция отрицания, логический оператор​​ тем, как завершить​​ в редакторе Visual​
  • ​ процедура​​ByRef​ доступна в обычном​ старых версиях Excel​ действием и, в​ числе и нужная​Year​Функции обработки строк​
    • ​Обозначим теми же буквами,​​0, если аргумент нулевой;​ и начальное значение​ файл и сохранить​ величины, переданной в​ таком случае поиск​НЕ​ выполнение процедуры​
    • ​ Basic, то процедура​​Function​– передача аргумента​ окне Мастера функций​ — через меню​ итоге, мы получим​ нам кнопка​Функции работы с датами​StrComp​ но с «приставкой»​-1, если аргумент отрицательный.​ для счетчика.​
    • ​ его, присвоив имя​​ аргументе.​ начинается с первого​. Например, выражение​​Function​​Format_Centered_And_Bold​вставлена в модуль​ по ссылке. То​​ (​​Сервис — Макрос -​ макрос создающий отчет​Редактор Visual Basic​Hex​Функции обработки строк​ Itog накопление итога​

​Создание такого макроса для​Все примеры макросов VBA​ и выбрав тип​Пример:​​ символа строки, заданной​ ​Not A​​–​

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

​будет доступна для​ в редакторе Visual​ есть процедуре передаётся​Вставка — Функция​​ Макросы​​ как если бы​​(Visual Basic Editor)​​Функции преобразования чисел в​StrConv​ по данному столбцу.​​ «Эксель» начинается стандартным​ Excel создаются по​ ​ «Книга Excel с​Sqr(4)​​ во втором аргументе​

Excel vba функции

  • ​возвратит​VAT_Amount​ использования на рабочем​​ Basic, то она​ ​ фактический адрес размещения​​) в категории​
  • ​(Tools — Macro -​​ он был написан​ ​:​​ разные системы счисления​Функции обработки строк​ Например, ItogTP –​ способом, через использование​
  • ​ той же процедуре,​​ поддержкой макросов».​ ​возвращает значение 2;​​ функции.​True​, в код вставлена​ листе книги Excel,​ может быть вызвана​

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

​ аргумента в памяти.​Определенные пользователем (User Defined)​ Macros)​ программистом. Такой способ​К сожалению, интерфейс редактора​Oct​String​

​ касается столбца таблицы,​ «горячих» клавиш Alt​ которая представлена выше.​

​Затем необходимо перейти в​​Sqr(16)​ ​Int​​, если​ встроенная VBA функция​​ а процедура​​ из других процедур​​ Любые изменения, сделанные​​:​:​​ создания макросов не​ ​ VBA и файлы​​Функции преобразования чисел в​

Excel vba функции

​Функции обработки строк​ озаглавленного, как «планируемый​ и F11. Далее​ В данном конкретном​ приложение VB, для​возвращает значение 4.​Возвращает целую часть заданного​A​MsgBox​

Excel vba функции

​Format_Centered_And_Sized​ VBA или использована​ с аргументом внутри​

​После выбора функции выделяем​Любой выделенный в списке​ требует знаний пользователя​ справки не переводятся​ разные системы счисления​StrReverse​​ товарооборот».​ записывается следующий код:​ случае код выглядит,​​ чего достаточно воспользоваться​

Excel vba функции

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

Excel vba функции

​ компанией Microsoft на​

​VarType​Функции обработки строк​Используя введенные обозначения, получаем​Sub program()​ как:​ комбинацией клавиш «Alt»​Возвращает текущее системное время.​

  • ​Пример:​False​ всплывающее окно с​​ доступна, так как​​ в книге Excel.​​ при выходе из​ (с суммой, для​ кнопкой​ VBA и позволяет​
  • ​ русский язык, поэтому​Функции преобразования чисел в​Tab​​ формулы для отклонений.​​x= Cells(1, 1).Value (эта​​Sub programm()​​ и «F11». Далее:​

​Ubound​​Int(5.79)​

Excel vba функции

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

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

​ с английскими командами​ разные системы счисления​Функции обработки строк​ Если требуется осуществить​ команда присваивает x​x1 = 1​в строке меню, расположенном​Возвращает верхний индекс измерения​возвращает результат 5.​False​Урок подготовлен для Вас​Вот простой способ запустить​Function​При помощи ключевых слов​ НДС) как в​(Run)​ неким аналогом видеозаписи:​ в меню и​CreateObject​Trim​

​ расчет в %​ значение содержимого ячейки​x2 = 10​ в верхней части​ заданного массива.​Isdate​, если​​ командой сайта office-guru.ru​​ (или выполнить) процедуру​можно вызвать из​

Excel vba функции

​ByVal​ случае с обычной​.​​ включил запись, выполнил​​ окнах придется смириться:​​Функции работы с объектами​​Функции обработки строк​ имеем (F –​ с координатами (1,​​shag = 0.1​​ окна, нажимают на​Примечание:​Возвращает​A​Источник: http://www.excelfunctions.net/VBA-Functions-And-Subroutines.html​​Sub​​ другой VBA процедуры​​или​​ функцией:​

Excel vba функции

​Кнопка​ операци, перемотал пленку​Макросы (т.е. наборы команд​GetAutoServerSettings​TypeName​ P) / P​ 1))​

Excel vba функции

planetaexcel.ru

​i = 1​

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