Создание пользовательской функции в VBA Excel, ее синтаксис и компоненты. Описание пользовательской функции и ее аргументов. Метод Application.MacroOptions.
Пользовательская функция — это процедура VBA, которая производит заданные вычисления и возвращает полученный результат. Используется для вставки в ячейки рабочего листа Excel или для вызова из других процедур.
Объявление пользовательской функции
Синтаксис функции
[Static] Function Имя ([СписокАргументов])[As ТипДанных] [Операторы] [Имя = выражение] [Exit Function] [Операторы] [Имя = выражение] End Function |
Компоненты функции
- Static — необязательное ключевое слово, указывающее на то, что значения переменных, объявленных в функции, сохраняются между ее вызовами.
- Имя — обязательный компонент, имя пользовательской функции.
- СписокАргументов — необязательный компонент, одна или более переменных, представляющих аргументы, которые передаются в функцию. Аргументы заключаются в скобки и разделяются между собой запятыми.
- Операторы — необязательный компонент, блок операторов (инструкций).
- Имя = выражение — необязательный* компонент, присвоение имени функции значения выражения или переменной. Обычно, значение присваивается функции непосредственно перед выходом из нее.
- Exit Function — необязательный компонент, принудительный выход из функции, если ей уже присвоено окончательное значение.
*Один из компонентов Имя = выражение следует считать обязательным, так как если не присвоить функции значения, смысл ее использования теряется.
Видимость функции
Видимость пользовательской функции определяется необязательными ключевыми словами Public и Private, которые могут быть указаны перед оператором Function (или Static, в случае его использования).
Ключевое слово Public указывает на то, что функция будет доступна для вызова из других процедур во всех модулях открытых книг Excel. Функция, объявленная как Public, отображается в диалоговом окне Мастера функций.
Ключевое слово Private указывает на то, что функция будет доступна для вызова из других процедур только в пределах программного модуля, в котором она находится. Функция, объявленная как Private, не отображается в диалоговом окне Мастера функций, но ее можно ввести в ячейку вручную.
Если ключевое слово Public или Private не указано, функция считается по умолчанию объявленной, как Public.
Чтобы пользовательская функция всегда была доступна во всех открытых книгах Excel, сохраните ее в Личной книге макросов без объявления видимости или как Public. Но если вы планируете передать рабочую книгу с пользовательской функцией на другой компьютер, код функции должен быть в программном модуле передаваемой книги.
Пример пользовательской функции
Для примера мы рассмотрим простейшую пользовательскую функцию, которой в следующем параграфе добавим описание. Называется функция «Деление», объявлена с типом данных Variant, так как ее возвращаемое значение может быть и числом, и текстом. Аргументы функции — Делимое и Делитель — тоже объявлены как Variant, так как в ячейках Excel могут быть числовые значения разных типов, и функция IsNumeric тоже проверяет разные типы данных и требует, чтобы ее аргументы были объявлены как Variant.
Function Деление(Делимое As Variant, Делитель As Variant) As Variant If IsNumeric(Делимое) = False Or IsNumeric(Делитель) = False Then Деление = «Ошибка: Делимое и Делитель должны быть числами!» Exit Function ElseIf Делитель = 0 Then Деление = «Ошибка: деление на ноль!» Exit Function Else Деление = Делимое / Делитель End If End Function |
Эта функция выполняет деление значений двух ячеек рабочего листа Excel. Перед делением проверяются два блока условий:
- Если делимое или делитель не являются числом, функция возвращает значение: «Ошибка: Делимое и Делитель должны быть числами!», и производится принудительный выход из функции оператором Exit Function.
- Если делитель равен нулю, функция возвращает значение: «Ошибка: деление на ноль!», и производится принудительный выход из функции оператором Exit Function.
Если проверяемые условия не выполняются (возвращают значение False) производится деление чисел и функция возвращает частное (результат деления).
Вы можете скопировать к себе в стандартный модуль эту функцию и она станет доступна в разделе «Определенные пользователем» Мастера функций. Попробуйте вставить функцию «Деление» в ячейку рабочего листа с помощью Мастера и поэкспериментируйте с ней.
Практического смысла функция «Деление» не имеет, но она хорошо демонстрирует как объявляются, создаются и работают пользовательские функции в VBA Excel. А еще она поможет продемонстрировать, как добавлять к функциям и аргументам описания. С полноценной пользовательской функцией вы можете ознакомиться здесь.
Добавление описания функции
В списке функций, выводимом Мастером, невозможно добавить или отредактировать их описание. Список макросов позволяет добавлять процедурам описание, но в нем нет функций. Проблема решается следующим образом:
- Запустите Мастер функций, посмотрите, как отображается имя нужной функции и закройте его.
- Откройте список макросов и в поле «Имя макроса» впишите имя пользовательской функции.
- Нажмите кнопку «Параметры» и в открывшемся окне добавьте или отредактируйте описание.
- Нажмите кнопку «OK», затем в окне списка макросов — «Отмена». Описание готово!
Добавление описания на примере функции «Деление»:
Добавление описания пользовательской функции
Описание функции «Деление» в диалоговом окне Мастера функций «Аргументы функции»:
Описание пользовательской функции в окне «Аргументы функции»
С помощью окна «Список макросов» можно добавить описание самой функции, а ее аргументам нельзя. Но это можно сделать, используя метод Application.MacroOptions.
Метод Application.MacroOptions
Метод Application.MacroOptions позволяет добавить пользовательской функции описание, назначить сочетание клавиш, указать категорию, добавить описания аргументов и добавить или изменить другие параметры. Давайте рассмотрим возможности этого метода, используемые чаще всего.
Пример кода с методом Application.MacroOptions:
Sub ИмяПодпрограммы() Application.MacroOptions _ Macro:=«ИмяФункции», _ Description:=«Описание функции», _ Category:=«Название категории», _ ArgumentDescriptions:=Array(«Описание 1», «Описание 2», «Описание 3», ...) End Sub |
- ИмяПодпрограммы — любое уникальное имя, подходящее для наименования процедур.
- ИмяФункции — имя функции, параметры которой добавляются или изменяются.
- Описание функции — описание функции, которое добавляется или изменяется.
- Название категории — название категории в которую будет помещена функция. Если параметр Category отсутствует, пользовательская функция будет записана в раздел по умолчанию — «Определенные пользователем». Если указанное Название категории соответствует одному из названий стандартного списка, функция будет записана в него. Если такого Названия категории нет в списке, будет создан новый раздел с этим названием и функция будет помещена в него.
- «Описание 1», «Описание 2», «Описание 3», … — описания аргументов в том порядке, как они расположены в объявлении пользовательской функции.
Эта подпрограмма запускается один раз, после чего ее можно удалить или использовать как шаблон для корректировки параметров других пользовательских функций.
Сейчас с помощью метода Application.MacroOptions попробуем изменить описание пользовательской функции «Деление» и добавить описания аргументов.
Sub ИзменениеОписания() Application.MacroOptions _ Macro:=«Деление», _ Description:=«Описание функции Деление изменено методом Application.MacroOptions», _ ArgumentDescriptions:=Array(«- любое числовое значение», «- числовое значение, кроме нуля») End Sub |
После однократного запуска этой подпрограммы получаем следующий результат:
Новое описание пользовательской функции и ее второго аргумента
Метод Application.MacroOptions не работает в Личной книге макросов, но и здесь можно найти решение. Добавьте описания к пользовательским функциям и их аргументам в обычной книге Excel, затем экспортируйте модуль с функциями в любой каталог на жестком диске и оттуда импортируйте в Личную книгу макросов. Все описания сохранятся.
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.
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.
The value of 50 would always be returned.
You can also call the GetRange function from a Sub Procedure.
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.
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.
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.
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 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!
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
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
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.
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 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.
Select User Defined from the Category List
Select the function you require from the available User Defined Functions (UDF’s).
Alternatively, when you start writing your function in Excel, the function should appear in the drop down list of functions.
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.
Interestingly enough, however, you can still use the function – it just will not appear in the list when looking for it!
If you have declared the second argument as Optional, you can omit it within the Excel sheet as well as within the VBA code.
You can also use the a function that you have created without arguments in your Excel sheet.
На чтение 31 мин. Просмотров 15.3k.
С помощью VBA вы можете создать пользовательскую функцию, которую можно использовать на листах точно так же, как обычные функции.
Это полезно, когда существующих функций Excel недостаточно. В таких случаях вы можете создать свою собственную пользовательскую функцию (UDF) для удовлетворения ваших конкретных потребностей.
В этом руководстве я расскажу о создании и использовании пользовательских функций в VBA.
Содержание
- Что такое функциональная процедура в VBA?
- Создание простой пользовательской функции в VBA
- Анатомия пользовательской функции в VBA
- Аргументы в пользовательской функции в VBA
- Создание функции, которая возвращает массив
- Понимание объема пользовательской функции в Excel
- Различные способы использования пользовательской функции в Excel
- Создание надстройки
- Сохранение функции в персональной книге макросов
- Ссылка на функцию из другой книги
- Использование оператора выхода из VBA
- Отладка пользовательской функции
- Встроенные функции Excel против Пользовательской функции VBA
- Где разместить код VBA для пользовательской функции
Что такое функциональная процедура в VBA?
Процедура Function — это код VBA, который выполняет вычисления и возвращает значение (или массив значений).
Используя процедуру Function, вы можете создать функцию, которую вы можете использовать на рабочем листе (как и любую обычную функцию Excel, такую как SUM или VLOOKUP).
Когда вы создали процедуру Function с использованием VBA, вы можете использовать ее тремя способами:
- В качестве формулы на рабочем листе, где она может принимать аргументы в качестве входных данных и возвращать значение или массив значений.
- Как часть кода вашей подпрограммы VBA или другого кода функции.
- В условном форматировании
Хотя на рабочем листе уже имеется более 450 встроенных функций Excel, вам может потребоваться настраиваемая функция, если:
- Встроенные функции не могут делать то, что вы хотите сделать. В этом случае вы можете создать пользовательскую функцию на основе ваших требований.
- Встроенные функции могут выполнять работу, но формула длинная и сложная. В этом случае вы можете создать пользовательскую функцию, которую легко читать и использовать
Обратите внимание, что пользовательские функции, созданные с использованием VBA, могут быть значительно медленнее, чем встроенные функции. Следовательно, они лучше всего подходят для ситуаций, когда вы не можете получить результат, используя встроенные функции.
Функция против Подпрограммы в VBA
«Подпрограмма» позволяет вам выполнять набор кода, в то время как «Функция» возвращает значение (или массив значений).
Например, если у вас есть список чисел (как положительных, так и отрицательных), и вы хотите идентифицировать отрицательные числа, вот что вы можете сделать с помощью функции и подпрограммы.
Подпрограмма может проходить через каждую ячейку в диапазоне и может выделять все ячейки, которые имеют отрицательное значение в ней. В этом случае подпрограмма завершает изменение свойств объекта диапазона (путем изменения цвета ячеек).
С пользовательской функцией вы можете использовать ее в отдельном столбце, и она может возвратить TRUE, если значение в ячейке отрицательное, и FALSE, если оно положительное. С помощью функции вы не можете изменять свойства объекта. Это означает, что вы не можете изменить цвет ячейки с помощью самой функции (однако вы можете сделать это, используя условное форматирование с пользовательской функцией).
Когда вы создаете пользовательскую функцию (UDF) с использованием VBA, вы можете использовать эту функцию на листе, как и любую другую функцию. Я расскажу об этом подробнее в разделе «Различные способы использования пользовательских функций в Excel».
Создание простой пользовательской функции в VBA
Позвольте мне создать простую пользовательскую функцию в VBA и показать вам, как она работает.
Приведенный ниже код создает функцию, которая извлекает числовые части из буквенно-цифровой строки.
Function GetNumeric(CellRef As String) as Long Dim StringLength As Integer StringLength = Len(CellRef) For i = 1 To StringLength If IsNumeric(Mid(CellRef, i, 1)) Then Result = Result & Mid(CellRef, i, 1) Next i GetNumeric = Result End Function
Если у вас есть вышеуказанный код в модуле, вы можете использовать эту функцию в рабочей книге.
Ниже показано, как эту функцию — GetNumeric — можно использовать в Excel.
Теперь, прежде чем я расскажу вам, как эта функция создается в VBA и как она работает, вам нужно знать несколько вещей:
- Когда вы создаете функцию в VBA, она становится доступной во всей книге, как и любая другая обычная функция.
- Когда вы вводите имя функции, за которым следует знак равенства, Excel покажет вам имя функции в списке совпадающих функций. В приведенном выше примере, когда я ввел = Get, Excel показал мне список, в котором была моя пользовательская функция.
Я считаю, что это хороший пример, когда вы можете использовать VBA для создания простой в использовании функции в Excel. Вы можете сделать то же самое с формулой (как показано в этом руководстве), но это становится сложным и трудным для понимания. С этим UDF вам нужно передать только один аргумент, и вы получите результат.
Анатомия пользовательской функции в VBA
В приведенном выше разделе я дал вам код и показал, как функция UDF работает на рабочем листе.
Теперь давайте углубимся и посмотрим, как создается эта функция. Вы должны поместить приведенный ниже код в модуль в VB Editor. Я рассматриваю эту тему в разделе «Где разместить код VBA для пользовательской функции».
Function GetNumeric(CellRef As String) as Long ' Эта функция извлекает числовую часть из строки Dim StringLength As Integer StringLength = Len(CellRef) For i = 1 To StringLength If IsNumeric(Mid(CellRef, i, 1)) Then Result = Result & Mid(CellRef, i, 1) Next i GetNumeric = Result End Function
Первая строка кода начинается со слова «Функция».
Это слово говорит VBA, что наш код является функцией (а не подпрограммой). За словом Function следует имя функции — GetNumeric. Это имя, которое мы будем использовать на листе, чтобы использовать эту функцию.
- В имени функции не должно быть пробелов. Кроме того, вы не можете назвать функцию, если она конфликтует с именем ссылки на ячейку. Например, вы не можете назвать функцию ABC123, так как она также относится к ячейке на листе Excel.
- Вы не должны давать своей функции то же имя, что и у существующей функции. Если вы сделаете это, Excel будет отдавать предпочтение встроенной функции.
- Вы можете использовать подчеркивание, если хотите разделить слова. Например, Get_Numeric является допустимым именем
За именем функции следуют некоторые аргументы в скобках. Это аргументы, которые нужны нашей функции от пользователя. Это как аргументы, которые мы должны предоставить встроенным функциям Excel. Например, в функции COUNTIF есть два аргумента (диапазон и критерии).
В скобках необходимо указать аргументы.
В нашем примере есть только один аргумент — CellRef.
Также полезно указывать, какой аргумент ожидает функция. В этом примере, так как мы будем передавать функции ссылку на ячейку, мы можем указать аргумент как тип «Range». Если вы не укажете тип данных, VBA будет рассматривать его как вариант (что означает, что вы можете использовать любой тип данных).
Если у вас есть более одного аргумента, вы можете указать те же в круглых скобках — через запятую. Далее в этом руководстве мы увидим, как использовать несколько аргументов в пользовательской функции.
Обратите внимание, что функция указана как тип данных «String». Это сообщит VBA, что результат формулы будет иметь тип данных String.
Здесь я могу использовать числовой тип данных (например, Long или Double), но это ограничит диапазон возвращаемых чисел. Если у меня есть строка длиной 20 номеров, которую мне нужно извлечь из общей строки, объявление функции как Long или Double приведет к ошибке (так как число будет вне диапазона). Поэтому я сохранил тип выходных данных функции как String.
Вторая строка кода — зеленая, которая начинается с апострофа — это комментарий. При чтении кода VBA игнорирует эту строку. Вы можете использовать это, чтобы добавить описание или подробности о коде.
Третья строка кода объявляет переменную StringLength как тип данных Integer. Это переменная, в которой мы храним значение длины строки, которая анализируется по формуле.
В четвертой строке переменная Result объявляется как тип данных String. Это переменная, в которой мы будем извлекать числа из буквенно-цифровой строки.
Пятая строка назначает длину строки во входном аргументе переменной «StringLength». Обратите внимание, что «CellRef» относится к аргументу, который будет предоставлен пользователем при использовании формулы в рабочей таблице (или при использовании ее в VBA — которую мы увидим позже в этом руководстве).
Шестая, седьмая и восьмая строки являются частью цикла For Next. Цикл выполняется столько раз, сколько символов во входном аргументе. Этот номер задается функцией LEN и присваивается переменной «StringLength».
Таким образом, цикл проходит от «1 до Stringlength».
Внутри цикла оператор IF анализирует каждый символ строки и, если он числовой, добавляет этот числовой символ в переменную Result. Для этого он использует функцию MID в VBA.
Вторая последняя строка кода присваивает значение результата функции. Именно эта строка кода гарантирует, что функция вернет значение «Result» обратно в ячейку (откуда она вызывается).
Последняя строка кода — End Function. Это обязательная строка кода, которая сообщает VBA, что код функции заканчивается здесь.
Приведенный выше код объясняет различные части типичной пользовательской функции, созданной в VBA. В следующих разделах мы углубимся в эти элементы, а также увидим различные способы выполнения функции VBA в Excel.
Аргументы в пользовательской функции в VBA
В приведенных выше примерах, где мы создали пользовательскую функцию для получения числовой части из буквенно-цифровой строки (GetNumeric), функция была разработана для получения одного аргумента.
В этом разделе я расскажу, как создавать функции, не имеющие аргументов, для функций, которые принимают несколько аргументов (как обязательных, так и необязательных).
Создание функции в VBA без каких-либо аргументов
В листе Excel у нас есть несколько функций, которые не принимают аргументов (например, RAND, TODAY, NOW).
Эти функции не зависят от входных аргументов. Например, функция TODAY возвращает текущую дату, а функция RAND возвращает случайное число в диапазоне от 0 до 1.
Вы можете создать такую же функцию в VBA.
Ниже приведен код, который даст вам имя файла. Он не принимает никаких аргументов, так как результат, который нужно вернуть, не зависит ни от одного аргумента.
Function WorkbookName() As String WorkbookName = ThisWorkbook.Name End Function
Приведенный выше код определяет результат функции как тип данных String (в качестве результата мы хотим получить имя файла, которое является строкой).
Эта функция присваивает функции значение «ThisWorkbook.Name», которое возвращается, когда функция используется на рабочем листе.
Если файл был сохранен, он возвращает имя с расширением файла, в противном случае он просто дает имя.
Выше есть одна проблема, хотя.
Если имя файла изменится, оно не будет автоматически обновлено. Обычно функция обновляется при изменении входных аргументов. Но поскольку в этой функции нет аргументов, функция не пересчитывает (даже если вы измените имя книги, закройте ее, а затем снова откройте).
При желании вы можете форсировать пересчет с помощью сочетания клавиш — Control + Alt + F9.
Чтобы формула пересчитывалась всякий раз, когда в рабочем листе есть изменения, вам нужна строка кода к ней.
Приведенный ниже код заставляет функцию пересчитывать всякий раз, когда происходит изменение в рабочем листе (как и в других аналогичных функциях рабочего листа, таких как функция TODAY или RAND).
Function WorkbookName() As String Application.Volatile True WorkbookName = ThisWorkbook.Name End Function
Теперь, если вы измените имя книги, эта функция будет обновляться всякий раз, когда будут какие-либо изменения в таблице, или когда вы снова откроете эту книгу.
Создание функции в VBA с одним аргументом
В одном из разделов выше мы уже видели, как создать функцию, которая принимает только один аргумент (функция GetNumeric, описанная выше).
Давайте создадим еще одну простую функцию, которая принимает только один аргумент.
Функция, созданная с помощью приведенного ниже кода, преобразует ссылочный текст в верхний регистр. Теперь у нас уже есть функция для этого в Excel, и эта функция просто показывает вам, как она работает. Если вам нужно сделать это, лучше использовать встроенную функцию UPPER.
Function ConvertToUpperCase(CellRef As Range) ConvertToUpperCase = UCase(CellRef) End Function
Эта функция использует функцию UCase в VBA для изменения значения переменной CellRef. Затем он присваивает значение функции ConvertToUpperCase.
Поскольку эта функция принимает аргумент, нам не нужно использовать здесь часть Application.Volatile. Как только аргумент изменится, функция автоматически обновится.
Создание функции в VBA с несколькими аргументами
Точно так же, как функции рабочего листа, вы можете создавать функции в VBA, которые принимают несколько аргументов.
Приведенный ниже код создаст функцию, которая будет извлекать текст перед указанным разделителем. Он принимает два аргумента — ссылку на ячейку с текстовой строкой и разделитель.
Function GetDataBeforeDelimiter(CellRef As Range, Delim As String) as String Dim Result As String Dim DelimPosition As Integer DelimPosition = InStr(1, CellRef, Delim, vbBinaryCompare) - 1 Result = Left(CellRef, DelimPosition) GetDataBeforeDelimiter = Result End Function
Когда вам нужно использовать более одного аргумента в пользовательской функции, вы можете иметь все аргументы в скобках, разделенные запятой.
Обратите внимание, что для каждого аргумента вы можете указать тип данных. В приведенном выше примере «CellRef» был объявлен как тип данных диапазона, а «Delim» был объявлен как тип данных String. Если вы не укажете какой-либо тип данных, VBA считает, что это вариант данных.
Когда вы используете вышеуказанную функцию на листе, вам нужно указать ссылку на ячейку, в которой в качестве первого аргумента указан текст, а в качестве двойного кавычка — символ (ы) в двойных кавычках.
Затем он проверяет положение разделителя с помощью функции INSTR в VBA. Эта позиция затем используется для извлечения всех символов перед разделителем (используя функцию LEFT).
Наконец, он присваивает результат функции.
Эта формула далека от совершенства. Например, если вы введете разделитель, который не найден в тексте, он выдаст ошибку. Теперь вы можете использовать функцию IFERROR на листе, чтобы избавиться от ошибок, или вы можете использовать приведенный ниже код, который возвращает весь текст, когда он не может найти разделитель.
Function GetDataBeforeDelimiter(CellRef As Range, Delim As String) as String Dim Result As String Dim DelimPosition As Integer DelimPosition = InStr(1, CellRef, Delim, vbBinaryCompare) - 1 If DelimPosition < 0 Then DelimPosition = Len(CellRef) Result = Left(CellRef, DelimPosition) GetDataBeforeDelimiter = Result End Function
Мы можем дополнительно оптимизировать эту функцию.
Если вы введете текст (из которого вы хотите извлечь часть перед разделителем) непосредственно в функции, это приведет к ошибке. Давай .. попробуй!
Это происходит, когда мы указали «CellRef» в качестве типа данных диапазона.
Или, если вы хотите, чтобы разделитель находился в ячейке и использовал ссылку на ячейку вместо жесткого кодирования в формуле, вы не можете сделать это с помощью приведенного выше кода. Это потому, что Delim был объявлен как строковый тип данных.
Если вы хотите, чтобы функция имела гибкость, позволяющую принимать прямой ввод текста или ссылки на ячейки от пользователя, вам необходимо удалить объявление типа данных. Это приведет к созданию аргумента в качестве альтернативного типа данных, который может принимать аргументы любого типа и обрабатывать их.
Код ниже сделает это:
Function GetDataBeforeDelimiter(CellRef, Delim) As String Dim Result As String Dim DelimPosition As Integer DelimPosition = InStr(1, CellRef, Delim, vbBinaryCompare) - 1 If DelimPosition < 0 Then DelimPosition = Len(CellRef) Result = Left(CellRef, DelimPosition) GetDataBeforeDelimiter = Result End Function
Создание функции в VBA с необязательными аргументами
В Excel есть много функций, некоторые из которых не являются обязательными.
Например, легендарная функция VLOOKUP имеет 3 обязательных аргумента и один необязательный аргумент.
Необязательный аргумент, как следует из названия, указывать необязательно. Если вы не укажете один из обязательных аргументов, ваша функция выдаст вам ошибку, но если вы не укажете необязательный аргумент, ваша функция будет работать.
Но необязательные аргументы не бесполезны. Они позволяют вам выбирать из целого ряда вариантов.
Например, в функции VLOOKUP, если вы не указали четвертый аргумент, VLOOKUP выполняет приблизительный поиск, а если вы указываете последний аргумент как FALSE (или 0), то он выполняет точное совпадение.
Помните, что необязательные аргументы всегда должны идти после всех обязательных аргументов. Вы не можете иметь дополнительные аргументы в начале.
Теперь давайте посмотрим, как создать функцию в VBA с необязательными аргументами.
Функция только с необязательным аргументом
Насколько я знаю, нет встроенной функции, которая принимает только необязательные аргументы (я могу ошибаться, но я не могу думать ни о какой такой функции).
Но мы можем создать один с VBA.
Ниже приведен код функции, которая выдаст вам текущую дату в формате dd-mm-yyyy, если вы не вводите никаких аргументов (т.е. оставьте это поле пустым), и в формате «dd mmmm, yyyy», если вы введете что-либо в качестве аргумента (т. е. что угодно, чтобы аргумент не был пустым).
Function CurrDate(Optional fmt As Variant) Dim Result If IsMissing(fmt) Then CurrDate = Format(Date, "dd-mm-yyyy") Else CurrDate = Format(Date, "dd mmmm, yyyy") End If End Function
Обратите внимание, что вышеупомянутая функция использует IsMissing, чтобы проверить, отсутствует аргумент или нет. Чтобы использовать функцию IsMissing, необязательный аргумент должен иметь вариантный тип данных.
Вышеуказанная функция работает независимо от того, что вы вводите в качестве аргумента. В коде мы только проверяем, указан ли необязательный аргумент или нет.
Вы можете сделать это более надежным, взяв только определенные значения в качестве аргументов и показывая ошибку в остальных случаях (как показано в приведенном ниже коде).
Function CurrDate(Optional fmt As Variant) Dim Result If IsMissing(fmt) Then CurrDate = Format(Date, "dd-mm-yyyy") ElseIf fmt = 1 Then CurrDate = Format(Date, "dd mmmm, yyyy") Else CurrDate = CVErr(xlErrValue) End If End Function
Приведенный выше код создает функцию, которая показывает дату в формате «дд-мм-гггг», если аргумент не указан, и в формате «дд мммм, гггг», если аргумент равен 1. Во всех других случаях выдается ошибка.
Функция с необходимыми и необязательными аргументами
Мы уже видели код, который извлекает числовую часть из строки.
Теперь давайте рассмотрим похожий пример, который принимает как обязательные, так и необязательные аргументы.
Приведенный ниже код создает функцию, которая извлекает текстовую часть из строки. Если необязательный аргумент равен TRUE, он дает результат в верхнем регистре, а если необязательный аргумент имеет значение FALSE или опущен, он дает результат как есть.
Function GetText(CellRef As Range, Optional TextCase = False) As String Dim StringLength As Integer Dim Result As String StringLength = Len(CellRef) For i = 1 To StringLength If Not (IsNumeric(Mid(CellRef, i, 1))) Then Result = Result & Mid(CellRef, i, 1) Next i If TextCase = True Then Result = UCase(Result) GetText = Result End Function
Обратите внимание, что в приведенном выше коде мы инициализировали значение «TextCase» как False (смотрите в скобках в первой строке).
Сделав это, мы убедились, что необязательный аргумент начинается со значения по умолчанию, то есть FALSE. Если пользователь указывает значение как ИСТИНА, функция возвращает текст в верхнем регистре, а если пользователь указывает необязательный аргумент как ЛОЖЬ или пропускает его, то возвращаемый текст остается как есть.
Создание функции в VBA с массивом в качестве аргумента
До сих пор мы видели примеры создания функции с необязательными / обязательными аргументами, где эти аргументы были одним значением.
Вы также можете создать функцию, которая может принимать массив в качестве аргумента. В функциях листа Excel есть много функций, которые принимают аргументы массива, такие как SUM, VLOOKUP, SUMIF, COUNTIF и т.д.
Ниже приведен код, который создает функцию, которая дает сумму всех четных чисел в указанном диапазоне ячеек.
Function AddEven(CellRef as Range) Dim Cell As Range For Each Cell In CellRef If IsNumeric(Cell.Value) Then If Cell.Value Mod 2 = 0 Then Result = Result + Cell.Value End If End If Next Cell AddEven = Result End Function
Вы можете использовать эту функцию на листе и указать диапазон ячеек, в которых в качестве аргумента используются числа. Функция будет возвращать одно значение — сумму всех четных чисел (как показано ниже).
В приведенной выше функции вместо одного значения мы предоставили массив (A1: A10). Чтобы это работало, вам нужно убедиться, что ваш тип данных аргумента может принимать массив.
В приведенном выше коде я указал аргумент CellRef как Range (который может принимать массив в качестве входных данных). Вы также можете использовать вариантный тип данных здесь.
В коде есть цикл For Each, который проходит через каждую ячейку и проверяет, является ли это число не. Если это не так, ничего не происходит, и он перемещается в следующую ячейку. Если это число, оно проверяет, является ли оно четным или нет (с помощью функции MOD).
В конце все четные числа добавляются, и сумма возвращается обратно в функцию.
Создание функции с неопределенным числом аргументов
При создании некоторых функций в VBA вы можете не знать точное количество аргументов, которые пользователь хочет предоставить. Поэтому необходимо создать функцию, которая может принимать столько аргументов, сколько необходимо, и использовать их для возврата результата.
Примером такой функции рабочего листа является функция SUM. Вы можете предоставить несколько аргументов (например, это):
= SUM (A1, A2: A4, B1: B20)
Вышеупомянутая функция добавит значения во все эти аргументы. Также обратите внимание, что это может быть одна ячейка или массив ячеек.
Вы можете создать такую функцию в VBA, указав последний аргумент (или единственный аргумент) в качестве необязательного. Кроме того, этому необязательному аргументу должно предшествовать ключевое слово «ParamArray».
ParamArray — это модификатор, который позволяет вам принимать столько аргументов, сколько вы хотите. Обратите внимание, что использование слова ParamArray перед аргументом делает аргумент необязательным. Однако вам не нужно использовать здесь слово «Необязательно».
Теперь давайте создадим функцию, которая может принимать произвольное количество аргументов и добавит все числа в указанные аргументы:
Function AddArguments(ParamArray arglist() As Variant) For Each arg In arglist AddArguments = AddArguments + arg Next arg End Function
Вышеприведенная функция может принимать любое количество аргументов и добавлять эти аргументы для получения результата.
Обратите внимание, что в качестве аргумента вы можете использовать только одно значение, ссылку на ячейку, логическое значение или выражение. Вы не можете предоставить массив в качестве аргумента. Например, если один из ваших аргументов — D8: D10, эта формула выдаст вам ошибку.
Если вы хотите использовать оба аргумента из нескольких ячеек, вам нужно использовать следующий код:
Function AddArguments(ParamArray arglist() As Variant) For Each arg In arglist For Each Cell In arg AddArguments = AddArguments + Cell Next Cell Next arg End Function
Обратите внимание, что эта формула работает с несколькими ячейками и ссылками на массивы, однако она не может обрабатывать жестко закодированные значения или выражения. Вы можете создать более надежную функцию, проверяя и обрабатывая эти условия, но это не является целью.
Цель здесь — показать вам, как работает ParamArray, чтобы вы могли разрешить неопределенное количество аргументов в функции. Если вам нужна функция лучше, чем та, которая была создана в приведенном выше коде, используйте функцию SUM на листе.
Создание функции, которая возвращает массив
До сих пор мы видели функции, которые возвращают одно значение.
С помощью VBA вы можете создать функцию, которая возвращает вариант, содержащий целый массив значений.
Формулы массивов также доступны в виде встроенных функций на листах Excel. Если вы знакомы с формулами массива в Excel, вы знаете, что они вводятся клавишами Control + Shift + Enter (а не только Enter). Вы можете прочитать больше о формулах массива здесь. Если вы не знаете формул массива, не беспокойтесь, продолжайте читать.
Давайте создадим формулу, которая возвращает массив из трех чисел (1,2,3).
Код ниже сделает это.
Function ThreeNumbers() As Variant Dim NumberValue(1 To 3) NumberValue(1) = 1 NumberValue(2) = 2 NumberValue(3) = 3 ThreeNumbers = NumberValue End Function
В приведенном выше коде мы указали функцию ThreeNumbers в качестве варианта. Это позволяет ему содержать массив значений.
Переменная NumberValue объявлена как массив из 3 элементов. Он содержит три значения и присваивает его функции «Три числа».
Вы можете использовать эту функцию на рабочем листе. Введите эту функцию и нажмите клавиши Control + Shift + Enter (удерживайте клавиши Control и Shift и затем нажмите Enter).
Когда вы сделаете это, он вернет 1 в ячейке, но в действительности он содержит все три значения. Чтобы проверить это, используйте следующую формулу:
= MAX (ThreeNumbers ())
Используйте вышеуказанную функцию с Control + Shift + Enter. Вы заметите, что теперь результат равен 3, так как это самые большие значения в массиве, возвращаемом функцией Max, которая получает три числа в результате нашей пользовательской функции — ThreeNumbers.
Вы можете использовать ту же технику для создания функции, которая возвращает массив названий месяцев, как показано в приведенном ниже коде:
Function Months() As Variant Dim MonthName(1 To 12) MonthName(1) = "Январь" MonthName(2) = "Февраль" MonthName(3) = "Март" MonthName(4) = "Апрель" MonthName(5) = "Май" MonthName(6) = "Июнь" MonthName(7) = "Июль" MonthName(8) = "Август" MonthName(9) = "Сентябрь" MonthName(10) = "Октябрь" MonthName(11) = "Ноябрь" MonthName(12) = "Декабрь" Months = MonthName End Function
Теперь, когда вы введете функцию = Months () на листе Excel и используете Control + Shift + Enter, она вернет весь массив названий месяцев. Обратите внимание, что вы видите только январь в ячейке, поскольку это первое значение в массиве. Это не означает, что массив возвращает только одно значение.
Чтобы показать вам тот факт, что он возвращает все значения, сделайте это — выберите ячейку с формулой, перейдите на панель формул, выберите всю формулу и нажмите F9. Это покажет вам все значения, которые возвращает функция.
Вы можете использовать это, используя приведенную ниже формулу INDEX, чтобы получить список всех названий месяцев за один раз.
=INDEX(Months(),ROW())
Теперь, если у вас много значений, не рекомендуется назначать эти значения одно за другим (как мы делали выше). Вместо этого вы можете использовать функцию Array в VBA.
Поэтому тот же код, в котором мы создаем функцию «Месяцы», станет короче, как показано ниже:
Function Months() As Variant Months = Array("Январь", "Февраль", "Март", "Апрель", "Май", "Июнь", _ "Июль", "Август", "Сентябрь", "Октябрь", "Ноябрь", "Декабрь") End Function
Вышеупомянутая функция использует функцию Array для назначения значений непосредственно этой функции.
Обратите внимание, что все функции, созданные выше, возвращают горизонтальный массив значений. Это означает, что если вы выберете 12 горизонтальных ячеек (скажем, A1: L1) и введете формулу = Months () в ячейку A1, вы получите все названия месяцев.
Но что, если вы хотите эти значения в вертикальном диапазоне ячеек.
Вы можете сделать это, используя формулу TRANSPOSE на листе.
Просто выберите 12 вертикальных ячеек (смежные) и введите приведенную ниже формулу.
Функция может иметь две области действия — Public или Private.
- Общая область означает, что функция доступна для всех листов в рабочей книге, а также для всех процедур (вспомогательных и функциональных) во всех модулях в рабочей книге. Это полезно, когда вы хотите вызвать функцию из подпрограммы (мы увидим, как это делается в следующем разделе).
- Частная область означает, что функция доступна только в том модуле, в котором она существует. Вы не можете использовать его в других модулях. Вы также не увидите его в списке функций на рабочем листе. Например, если имя вашей функции — «Месяцы ()», и вы вводите функцию в Excel (после знака =), она не будет отображать вам имя функции. Однако вы все равно можете использовать его, если вводите название формулы
Если вы ничего не указали, функция по умолчанию является публичной.
Ниже приведена функция, которая является частной функцией:
Private Function WorkbookName() As String WorkbookName = ThisWorkbook.Name End Function
Вы можете использовать эту функцию в подпрограммах и процедурах в тех же модулях, но не можете использовать ее в других модулях. Эта функция также не будет отображаться на листе.
Приведенный ниже код сделает эту функцию публичной. Это также будет отображаться на листе.
Function WorkbookName() As String WorkbookName = ThisWorkbook.Name End Function
Различные способы использования пользовательской функции в Excel
Создав пользовательскую функцию в VBA, вы можете использовать ее по-разному.
Давайте сначала рассмотрим, как использовать функции на листе.
Использование пользовательских функций в рабочих листах
Мы уже видели примеры использования функции, созданной в VBA, на листе.
Все, что вам нужно сделать, это ввести имя функции, и оно отобразится в intellisense.
Обратите внимание, что для того, чтобы функция отображалась на рабочем листе, она должна быть функцией Public (как описано в разделе выше).
Вы также можете использовать диалоговое окно «Вставить функцию» для вставки пользовательской функции (используя шаги ниже). Это будет работать только для публичных функций.
- Перейдите на вкладку «Данные».
- Нажмите «Вставить функцию».
- В диалоговом окне «Вставка функции» выберите «Определено пользователем» в качестве категории. Эта опция отображается только тогда, когда у вас есть функция в редакторе VB (и функция Public).
- Выберите функцию из списка всех общедоступных пользовательских функций.
- Нажмите кнопку ОК
Вышеуказанные шаги вставят функцию в лист. Он также отображает диалоговое окно «Аргументы функции», которое предоставит вам подробную информацию об аргументах и результате.
Вы можете использовать пользовательскую функцию, как и любую другую функцию в Excel. Это также означает, что вы можете использовать его с другими встроенными функциями Excel. Например. приведенная ниже формула даст название рабочей книги в верхнем регистре:
=UPPER(WorkbookName())
Использование пользовательских функций в процедурах и функциях VBA
Когда вы создали функцию, вы можете использовать ее и в других подпроцедурах.
Если функция Public, она может использоваться в любой процедуре в том же или другом модуле. Если это Private, его можно использовать только в том же модуле.
Ниже приведена функция, которая возвращает имя рабочей книги.
Function WorkbookName() As String WorkbookName = ThisWorkbook.Name End Function
Приведенная ниже процедура вызывает функцию, а затем отображает имя в окне сообщения.
Sub ShowWorkbookName() MsgBox WorkbookName End Sub
Вы также можете вызвать функцию из другой функции.
В приведенных ниже кодах первый код возвращает имя рабочей книги, а второй возвращает имя в верхнем регистре, вызывая первую функцию.
Function WorkbookName() As String WorkbookName = ThisWorkbook.Name End Function
Function WorkbookNameinUpper() WorkbookNameinUpper = UCase(WorkbookName) End Function
Вызов пользовательской функции из других книг
Если у вас есть функция в рабочей книге, вы можете вызвать эту функцию и в других рабочих книгах.
Есть несколько способов сделать это:
- Создание надстройки
- Функция сохранения в персональной макрокоманде
- Ссылка на функцию из другой рабочей книги.
Создание надстройки
Создав и установив надстройку, вы получите настраиваемую функцию, доступную во всех книгах.
Предположим, вы создали пользовательскую функцию — «GetNumeric» и хотите, чтобы она была во всех книгах. Для этого создайте новую рабочую книгу и поместите код функции в модуль этой новой рабочей книги.
Теперь следуйте инструкциям ниже, чтобы сохранить его как надстройку, а затем установить его в Excel.
- Перейдите на вкладку «Файл» и нажмите «Сохранить как».
- В диалоговом окне «Сохранить как» измените тип «Сохранить как» на .xlam. Имя, которое вы назначаете файлу, будет именем вашей надстройки. В этом примере файл сохраняется с именем GetNumeric.
- Вы заметите, что путь к файлу, в котором он сохраняется, автоматически изменяется. Вы можете использовать по умолчанию или изменить его, если хотите.
- Откройте новую книгу Excel и перейдите на вкладку Разработчик.
- Выберите параметр «Надстройки Excel».
- В диалоговом окне «Надстройки» найдите и найдите сохраненный файл и нажмите «ОК».
Теперь надстройка была активирована.
Теперь вы можете использовать пользовательские функции во всех книгах.
Сохранение функции в персональной книге макросов
Персональная книга макросов — это скрытая рабочая книга в вашей системе, которая открывается при каждом запуске приложения Excel.
Это место, где вы можете хранить макросы и получать к ним доступ из любой книги. Это отличное место для хранения тех макросов, которые вы хотите часто использовать.
По умолчанию в вашем Excel нет личной книги макросов. Вам необходимо создать его, записав макрос и сохранив его в личной книге макросов.
Ссылка на функцию из другой книги
Хотя первые два метода (создание надстройки и использование личной рабочей книги макроса) будут работать во всех ситуациях, если вы хотите сослаться на функцию из другой рабочей книги, эта рабочая книга должна быть открыта.
Предположим, у вас есть рабочая книга с именем «Рабочая тетрадь с формулой», и она имеет функцию с именем «GetNumeric».
Чтобы использовать эту функцию в другой рабочей книге (когда рабочая книга с формулой открыта), вы можете использовать следующую формулу:
=’Workbook with Formula’!GetNumeric(A1)
Приведенная выше формула будет использовать пользовательскую функцию в файле Workbook with Formula и даст вам результат.
Обратите внимание: поскольку в имени книги есть пробелы, его необходимо заключить в одинарные кавычки.
Использование оператора выхода из VBA
Если вы хотите выйти из функции во время выполнения кода, вы можете сделать это с помощью оператора «Выход из функции».
Приведенный ниже код извлекает первые три числовых символа из буквенно-цифровой текстовой строки. Как только он получает три символа, функция завершается и возвращает результат.
Function GetNumericFirstThree(CellRef As Range) As Long Dim StringLength As Integer StringLength = Len(CellRef) For i = 1 To StringLength If J = 3 Then Exit Function If IsNumeric(Mid(CellRef, i, 1)) Then J = J + 1 Result = Result & Mid(CellRef, i, 1) GetNumericFirstThree = Result End If Next i End Function
Вышеприведенная функция проверяет количество числовых символов, и когда она получает 3 числовых символа, она выходит из функции в следующем цикле.
Отладка пользовательской функции
Есть несколько методов, которые вы можете использовать при отладке пользовательской функции в VBA:
Отладка пользовательской функции с помощью окна сообщения
Используйте функцию MsgBox, чтобы показать окно сообщения с определенным значением.
Отображаемое значение может быть основано на том, что вы хотите проверить. Например, если вы хотите проверить, выполняется ли код или нет, будет работать любое сообщение, и если вы хотите проверить, работают ли циклы или нет, вы можете отобразить определенное значение или счетчик цикла.
Отладка пользовательской функции путем установки точки останова
Установите точку останова, чтобы иметь возможность проходить шаг за шагом по каждой строке. Чтобы установить точку останова, выберите нужную строку и нажмите F9 или нажмите на серую вертикальную область, которая слева от строк кода. Любой из этих методов вставил бы точку останова (вы увидите красную точку в серой области).
Как только вы установили точку останова и выполнили функцию, она идет до линии точки останова и затем останавливается. Теперь вы можете просмотреть код с помощью клавиши F8. Нажмите F8 один раз, чтобы перейти к следующей строке в коде.
Отладка пользовательской функции с помощью Debug.Print в коде
Вы можете использовать оператор Debug.Print в своем коде, чтобы получить значения указанных переменных / аргументов в непосредственном окне.
Например, в приведенном ниже коде я использовал Debug.Print, чтобы получить значение двух переменных — «j» и «Result».
Function GetNumericFirstThree(CellRef As Range) As Long Dim StringLength As Integer StringLength = Len(CellRef) For i = 1 To StringLength If J = 3 Then Exit Function If IsNumeric(Mid(CellRef, i, 1)) Then J = J + 1 Result = Result & Mid(CellRef, i, 1) Debug.Print J, Result GetNumericFirstThree = Result End If Next i End Function
Когда этот код выполняется, он показывает следующее в immediate window.
Встроенные функции Excel против Пользовательской функции VBA
Есть несколько сильных преимуществ использования встроенных функций Excel по сравнению с пользовательскими функциями, созданными в VBA.
- Встроенные функции работают намного быстрее, чем функции VBA.
- Когда вы создаете отчет / панель мониторинга с использованием функций VBA и отправляете его клиенту / коллеге, им не нужно беспокоиться о том, включены макросы или нет. В некоторых случаях клиенты / клиенты пугаются, увидев предупреждение в желтой полосе (которое просто просит их включить макросы).
- Благодаря встроенным функциям Excel вам не нужно беспокоиться о расширениях файлов. Если у вас есть макросы или пользовательские функции в рабочей книге, вам нужно сохранить их в формате .xlsm
Хотя существует множество веских причин для использования встроенных функций Excel, в некоторых случаях лучше использовать пользовательскую функцию.
- Лучше использовать пользовательскую функцию, если ваша встроенная формула огромна и сложна. Это становится еще более актуальным, когда вам нужен кто-то еще, чтобы обновить формулы. Например, если у вас есть огромная формула, состоящая из множества различных функций, даже изменение ссылки на ячейку может быть утомительным и подверженным ошибкам. Вместо этого вы можете создать пользовательскую функцию, которая принимает только один или два аргумента и выполняет всю тяжелую работу с бэкэндом.
- Когда вам нужно что-то сделать, что не может быть сделано встроенными функциями Excel. Примером этого может быть случай, когда вы хотите извлечь все числовые символы из строки. В таких случаях польза от использования пользовательской функции gar перевешивает ее недостатки.
Где разместить код VBA для пользовательской функции
При создании пользовательской функции необходимо поместить код в окно кода для книги, в которой вы хотите использовать функцию.
Ниже приведены инструкции по размещению кода для функции «GetNumeric» в книге.
- Перейдите на вкладку Разработчик.
- Нажмите на Visual Basic. Это откроет редактор VB в бэкэнде.
- На панели Project Explorer в редакторе VB щелкните правой кнопкой мыши любой объект для книги, в которую вы хотите вставить код. Если вы не видите Project Explorer, перейдите на вкладку View и щелкните Project Explorer.
- Перейти к Вставить и нажмите на модуль. Это вставит объект модуля для вашей книги.
- Скопируйте и вставьте код в окно модуля.
Процедуры «Function» и «Sub» в VBA
Встроенные функции VBA
Смотрите такжеПараметры и запустил выполнение на языке VBA)Функции работы с объектамиФункции обработки строк * 100, аIf x>0 Then Cells(1,Do While x1 <
иконку рядом сДля многомерных массивовTrue
- равноПеревел: Антон Андронов, доступную из рабочего при помощи простогоByRefПеред тем, как приступить(Options) тех же действий
- хранятся в программныхGetObjectUCase в сумме — 1).Value = 1
- x2 (цикл будет иконкой Excel; в качестве необязательного, если заданное значениеTrueАвтор: Антон Андронов листа: присваивания этой процедурыв объявлении процедуры к созданию собственных
позволяет посмотреть и еще раз. Естественно модулях. В любойФункции работы с объектамиФункции обработки строк (F – P).
Пользовательские процедуры «Function» и «Sub» в VBA
If x=0 Then Cells(1, выполняться пока верновыбирают команду Mudule; аргумента может быть является датой, или.При написании кода VBAНажмите переменной. В следующем можно задать, каким функций VBA, полезно отредактировать сочетание клавиш у такого способа книге Excel мыIsObjectValРезультаты этих вычислений можно 1).Value = 0
выражение x1 <сохраняют, нажав на иконку указано, индекс какогоFalseВ приведённой выше таблице в Excel наборAlt+F8 примере показано обращение именно способом аргумент знать, что Excel для быстрого запуска есть свои плюсы можем создать любоеФункции работы с объектамиФункции обработки строк
Аргументы
лучше всего сразуIf x x2) с изображением floppy именно измерения нужо– если датой перечислены не все встроенных операторов используют(нажмите клавишу к процедуре передаётся процедуре. Ниже VBA располагает обширной макроса. и минусы: количество программных модулей
DDBCBool внести в соответствующие
End Sub.y=x1 + x1^2 + disk; возвратить. Если не не является. логические операторы, доступные на каждом шагу.AltSumMinus это показано на
Необязательные аргументы
коллекцией готовых встроенныхКнопкаМакрорекордер записывает только те и разместить тамФинансовые функцииФункции преобразования типа данных ячейки таблицы «Эксель».Остается запустить макрос и 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возвращает можно найти на операторы сравнения иF8Sub main() Dim Integer) … End кода.открывает редактор Visual
Microsoft Excel. Как любое количество макросов.IPmtCCur по формулам ItogP=ItogP аргумента. в ячейку сSub program ()Возвращает целое число, соответствующееTrue
сайте Visual Basic логические. Далее мы). | total as Double SubСписок этих функций можно Basic (см. выше) только вы закрываете Доступ ко всемФинансовые функцииФункции преобразования типа данных + P иКак вы уже могли |
координатами (i,1))’Наш код году в заданной | ; Developer Center. подробно рассмотрим каждуюВ появившемся списке макросов total = SumMinus(5,В этом случае целочисленный посмотреть в редакторе и позволяет просмотреть Excel или переключаетесь модулям осуществляется сIRRCDate ItogF=ItogF+ F. заметить, программировать в |
Cells(i, 2).Value = yEnd Sub дате.Пример:IsDate(100)В VBA доступно множество группу операторов. выберите тот, который 4, 3) End аргумент VBA: и отредактировать текст
в другую программу помощью окна ProjectФинансовые функцииФункции преобразования типа данныхДля отклонений используют = самом известном табличном (значение y записываетсяОбратите внимание, что строкаYear(«29/01/2015»)возвращает встроенных функций, которыеОсновные математические операторы VBA хотите запустить. SubiОткройте рабочую книгу Excel макроса на VBA.
VBA процедура «Function»
— запись останавливается. Explorer в левомMIRRCDbl (ItogF – ItogP) процессоре Microsoft не
в ячейку с «’Наш код» будет
возвращает значение 2015.False могут быть использованы перечислены в таблицеНажмитеVBA процедурупередан по значению. и запустите редактор
- Чтобы не запоминать сочетаниеМакрорекордер может записать только верхнем углу редактораФинансовые функцииФункции преобразования типа данных
- / ItogP * так уж сложно. координатами (i,2)) выделена другим цветомДанный список включает в. при написании кода. ниже.ВыполнитьFunction После выхода из VBA (нажмите для
клавиш для запуска те действия, для
Пример VBA процедуры «Function»: Выполняем математическую операцию с 3 числами
(если его неNPerCDec 100, если расчет Особенно, если научитьсяi = i + (зеленым). Причина в себя только избранныеIsError Ниже перечислены некоторыеВ правом столбце таблицы(Run)можно вызвать из процедуры этого
макроса, лучше создать которых есть команды видно, нажмите CTRL+R).Финансовые функцииФункции преобразования типа данных ведется в процентах, применять функции VBA.
1 (действует счетчик); апострофе, поставленном в наиболее часто употребляемыеВозвращает из наиболее часто указан приоритет операторов,Чтобы выполнять процедуру рабочего листа ExcelSubAlt+F11 кнопку и назначить меню или кнопки Программные модули бываютNPVCInt а в случае Всего в этомx1 = x1 + начале строки, который встроенные функции ExcelTrue
Вызов VBA процедуры «Function»
используемых: принятый по умолчаниюSub таким же образом,все сделанные с), и затем нажмите ей нужный макрос. в Excel. Программист нескольких типов дляФинансовые функцииФункции преобразования типа данных
Вызов VBA процедуры «Function» из другой процедуры
суммарной величины — языке программирования, созданном shag (аргумент изменяется обозначает, что далее Visual Basic. Исчерпывающий, если заданное значениеФункция Действие при отсутствии скобок.быстро и легко, как любую другуюiF2
Кнопка может быть же может написать разных ситуаций:PmtCLgn
Вызов VBA процедуры «Function» из рабочего листа
(ItogF – ItogP). специально для написания на величину шага); следует комментарий. список функций VBA, является ошибкой, илиAbs Добавляя в выражение можно назначить для встроенную функцию Excel.изменения будут утрачены.. нескольких типов: макрос, который делаетОбычные модулиФинансовые функции
Функции преобразования типа данных
VBA процедура «Sub»
Результаты опять же сразу приложений в «Эксель»LoopТеперь вы можете написать доступных для использованияFalseВозвращает абсолютную величину заданного
скобки, можно изменять неё комбинацию клавиш.
VBA процедура «Sub»: Пример 1. Выравнивание по центру и изменение размера шрифта в выделенном диапазоне ячеек
Следовательно, созданную вSub AddToCells(ByRef i AsВ выпадающем списке вКнопка на панели инструментов то, что Excel- используются вPPmtCSgn записываются в соответствующие и Word, околоEnd Sub. любой код и
в макросах Excel,– если ошибкой числа. порядок выполнения операторов Для этого: предыдущем примере процедуру
Integer) … End верхней левой части в Excel 2003 никогда не умел
большинстве случаев, когдаФинансовые функцииФункции преобразования типа данных ячейки, поэтому нет 160 функций. ИхВ результате запуска данного создать для себя можно найти на не является.Пример: VBA по своемуНажмитеFunction Sub экрана выберите библиотеку и старше (сортировку по цвету, речь идет оPV
VBA процедура «Sub»: Пример 2. Выравнивание по центру и применение полужирного начертания к шрифту в выделенном диапазоне ячеек
CStr необходимости их присваивания можно разделить на макроса в «Эксель» новый инструмент в сайте Visual BasicIsMissingAbs(-20) желанию.Alt+F8–
В этом случае целочисленныйVBAОткройте меню например или что-то макросах. Для создания
Вызов процедуры «Sub» в Excel VBA
Вызов VBA процедуры «Sub» из другой процедуры
Финансовые функцииФункции преобразования типа данных переменным. несколько больших групп. получаем два столбца, VBA Excel (примеры Developer Center.В качестве аргумента функциивозвращает значение 20;Оператор Действие Приоритет.SumMinus
аргумент.
Сервис — Настройка подобное). такого модуля выберитеRateCVarПеред запуском созданной программы,
Это: в первом из программ см. далее).
Вызов VBA процедуры «Sub» из рабочего листа
Урок подготовлен для Вас передаётся имя необязательногоAbs(20)(1 — высший;В появившемся списке макросовможно вызвать, введяiПоявится список встроенных классов(Tools — Customize)Если во время записи в менюФинансовые функцииФункции преобразования типа данных требуется сохранить рабочуюМатематические функции. Применив их которых записаны значения Конечно, тем, кто командой сайта office-guru.ru аргумента процедуры.возвращает значение 20. 5 — низший) выберите тот, которому в ячейку рабочегопередан по ссылке. и функций VBA.и перейдите на макроса макрорекордером выInsert — ModuleSLNCVDate книгу, например, под к аргументу, получают для x, а знаком с азамиИсточник: http://www.excelfunctions.net/VBA-Operators-And-Functions.htmlIsMissing
Chr^ хотите назначить сочетание листа вот такое После выхода из
- Кликните мышью по вкладку ошиблись — ошибка. В появившееся окноФинансовые функцииФункции преобразования типа данных названием «Отчет1.xls». значение косинуса, натурального
- во втором — Visual Basic, будетПеревел: Антон Андронов
- возвращаетВозвращает символ ANSI, соответствующийОператор возведения в степень
клавиш. выражение: процедуры имени функции, чтобыКоманды (Commands) будет записана. Однако
- нового пустого модуляSYDChoose
- Клавишу «Создать отчетную таблицу» логарифма, целой части для y. намного проще. Однако
- Автор: Антон АндроновTrue числовому значению параметра.1Нажмите
- =SumMinus(10, 5, 2)Sub внизу окна отобразилось. В категории смело можете давить можно вводить команды
Финансовые функцииФункции загрузки данных требуется нажать всего и пр.Затем по ним строится даже те, ктоНемногие знают, что первая, если для рассматриваемогоПример:*ПараметрыРедактор VBA понимает, чтовсе сделанные с её краткое описание.
Область действия процедуры VBA
Макросы на кнопку отмены на VBA, набираяFormatIIf 1 раз послеФинансовые функции. Благодаря их график способом, стандартным их не имеет, версия популярного продукта аргумента процедуры неChr(10)
Оператор умножения(Options) и в перед ним процедура | i Нажатиелегко найти веселый последнего действия (Undo) их с клавиатурыФункции форматированияФункции загрузки данных |
ввода заголовочной информации. наличию и используя для «Эксель». | при желании смогут Microsoft Excel появилась передано значение.возвращает перенос строки;2 появившемся диалоговом окнеSubизменения будут сохраненыF1 желтый «колобок» - — во время |
или копируя ихFormatCurrencyInputBox Следует знать и программирование в Excel,Для реализации циклов в освоиться достаточно быстро. в 1985 году.IsNumericChr(97)/ введите сочетание клавиш., когда встречает группу в переменной, котораяоткроет страницу онлайн-справкиНастраиваемую кнопку записи макроса макрорекордером из другого модуля,Функции форматированияФункции загрузки данных
Ранний выход из VBA процедур «Function» и «Sub»
другие правила. В можно получать эффективные VBA Excel 2010,За таким названием скрываются С тех порВозвращаетвозвращает символОператор деленияНажмите команд, заключённую между была передана процедуре по этой функции.(Custom button) она не просто с этого сайтаFormatDateTimeLoadPicture частности, кнопка «Добавить инструменты для ведения как и в программы, написанные на он пережил несколькоTruea2ОК вот такими открывающим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.
кнопкой мыши. В
Чтобы включить запись необходимо: | углу редактора VisualObjPtrLoadResString занесения всех данныхФункции VBA Excel для столбец. В каждой |
Операторы сравнения
нужным кодом. Благодаря малой толикой возможностей. к заданной дате.74Назначая сочетание клавишSub не использованы ключевыеВ Excel Visual Basic контекстом меню можно
в Excel 2003 и
Basic в окне, | Функции работы с указателями |
Функции загрузки данных | требуется нажать кнопку |
строки. Это достаточно | |
его ячейке будут | этой возможности табличный |
этого табличного процессора | |
Left | Синтаксис функции: |
Логические операторы
возвратит результат для макроса, убедитесь,, задача которой – слова набор команд, выполняющий назначить кнопке макрос, старше — выбрать которое называется Project
StrPtr
MsgBox | «Закончить» и затем многочисленная группа. В записаны квадраты номера процессор Microsoft саморазвивается, и даже неВозвращает заданное количество символовDateAdd(1 что оно не изменить форматирование выделенногоByVal определённую задачу, помещается выбрать другой значок в меню Explorer. В этотФункции работы с указателями |
Функции загрузки данных | переключиться в окно нее входят, например, соответствующей строки. Использование подстраиваясь под требования догадываются, как им от начала переданнойинтервал3 используется, как стандартное диапазона ячеек. Вили в процедуру и имя:Сервис — Макрос - модуль обычно записываютсяVarPtrCurDir «Эксель». функции Space для конструкции For позволит конкретного пользователя. Разобравшись |
могло бы облегчить | строки. Синтаксис функции,Mod в Excel (например, ячейках устанавливается выравниваниеByRefFunctionКнопка на панели быстрого Начать запись макросы, которые должныФункции работы с указателямиФункции работы с файламиТеперь вы знаете, как создания строки с записать ее очень с тем, как жизнь умение программирования |
вот такой:числоОператор модуля (остатка) –Ctrl+C по центру (и, то аргумент будет(Функция) или доступа в Excel
Встроенные функции
(Tools — Macro - выполнятся при наступленииВсем нам приходится -Dir решать задачи для числом пробелов, равных коротко, без использования
создавать модули для
в Excel. | Left(,
возвращает остаток от
|
|||||||||||||||||||||
2007 и новее | Record New Macro) каких-либо событий в
кому реже, кому
|
|||||||||||||||||||||
строка | дата | |||||||||||||||||||||
деления двух чисел. | существующее сочетание клавиш, по горизонтали) иПеред тем как продолжить
Asc для переводаСначала нужно создать макрос, приступать к рассмотрению посредством языка программирования,) Например, то оно будет размер шрифта изменяется изучение процедур между процедурами по панели быстрого новее — нажать сохранение книги, печать одни и те
Далее записываем сам
|
|||||||||||||||||||||
Запись макроса (Record macro) | Модуль листа операции в Excel.Функции работы с файлами
может понадобиться и
|
|||||||||||||||||||||
Sub | Excel и выберитена вкладке- доступен через
Любая офисная работаFileDateTime для работы в |
|||||||||||||||||||||
и позволяют работать | нас интересуют значения самых элементарных кодов. известный табличный процессор
строка интервала, добавляемого к. |
|||||||||||||||||||||
макроса случайно. | 10) Selection.HorizontalAlignment =более подробно, будетсостоит в том, командуРазработчик (Developer) Project Explorer и предполагает некую «рутиннуюФункции работы с файлами
среде самого популярного
В части 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
роль ключевых словSub Далее приведены краткие– нет.Затем в открывшемся окне: команда действия по обработке GetAttr
|
|||||||||||||||||||||
могут овладеть даже | начала строки..
Оператор вычитанияPublicвыполняет действия, но |
|||||||||||||||||||||
обсуждения процедур VBA | Поэтому, если требуется выполнить выберите категориюИмя макроса
Исходный текст (View Source) поступивших данных, заполнениеФункции работы с файлами |
|||||||||||||||||||||
начале статьи, или | значение аргумента Expression, язык, как «Повторятьоткрывают вкладку «Вид»;
пользователи, которые неПример:Аргумент5и не возвращает результат.Function действия и получитьМакросы- подойдет любое. Сюда записывают макросы, однообразных таблиц илиInput через написание кода преобразовав его в от 1 допереходят на пиктограмму «Макросы»; имеют навыков профессионального
|
|||||||||||||||||||||
В этом примере также | и какой-то результат (например,и при помощи имя на русском которые должны выполняться | |||||||||||||||||||||
бланков и т.д. | Функции работы с файлами создавать кнопки меню, | |||||||||||||||||||||
тип данных Variant. | 10 с шагомжмут на «Запись макроса»; программирования. К особенностям
возвращает строку «абвг»;может принимать одно Excel VBA –. Эти ключевые слова использован необязательный (Optional) Sub просуммировать несколько чисел), кнопки или английском языке. при наступлении определенных Использование макросов иLoc благодаря которым многиеФункции работы с датами. один».
|
|||||||||||||||||||||
это оператор конкатенации | так же можно аргументи показаны простые
то обычно используетсяДобавить (Add) Имя должно начинаться |
|||||||||||||||||||||
событий на листе | пользовательских функций позволяетФункции работы с файлами операции над текстом
Они значительно расширяют
|
|||||||||||||||||||||
Интервал Значение | & | |||||||||||||||||||||
использовать применительно к | iFontSize примеры.
процедураперенесите выбранный макрос с буквы и (изменение данных в автоматизировать эти операции,LOF можно будет осуществлять стандартные возможности «Эксель». столбец с квадратами, |
|||||||||||||||||||||
«Имя макроса» оставляют | офисных приложений.Lenyyyy(слияние): VBA процедурам: |
. Если аргументРедактор VBA распознаёт процедуруFunction в правую половину не содержать пробелов ячейках, пересчет листа, перекладывая монотонную однообразнуюФункции работы с файлами нажатием дежурных клавиш Так, функция WeekdayName например, всех нечетных
«Макрос1», а вНедостатком программы являются проблемы,
Возвращает количество символов в
год
Оператор Действие
office-guru.ru
VBA Excel: примеры программ. Макросы в Excel
Public Sub AddToCells(i AsiFontSizeFunction, а для того, окна, т.е. на и знаков препинания. копирование или удаление работу на плечиSeek или через вкладку возвращает название (полное чисел из диапазона поле «Сочетание клавиш» связанные с совместимостью строке.q& Integer) … End
Что такое VBA
не передан процедуре, когда встречает группу чтобы просто выполнить панель быстрого доступа:Сочетание клавиш листа и т.д.) Excel. Другим поводом
Функции работы с файлами «Вид» и пиктограмму или частичное) дня от 1 до вставляют, например, hh различных версий. ОниПример:кварталОператор конкатенации. К примеру, SubSub
команд, заключённую между какие-то действия (например,Кнопка на листе- будет потомОбычный макрос, введенный в для использования макросовCallByName «Макросы». недели по его 11, то пишем: (это значит, что обусловлены тем, чтоLen(«абвгдеж»)m выражениеЕсли перед объявлением процедуры, то его значение вот такими открывающим изменить форматирование группыЭтот способ подходит для использоваться для быстрого стандартный модуль выглядит
Объекты, коллекции, свойства и методы
в вашей работеФункции обработки системных параметровАвтор: Наира номеру. Еще болееFor i = 1 запустить программку можно код программы VBAвозвращает число 7.месяц«A» & «B» стоит ключевое слово по умолчанию принимается и закрывающим операторами:
ячеек), нужно выбрать любой версии Excel. запуска макроса. Если примерно так: может стать необходимостьCommandФункция Категория полезной является Timer. to 10 step будет блиц-командой «Ctrl+h»).
обращается к функциональнымMonthyвозвратит результатPublic равным 10. ОднакоFunction … End процедуру
Мы добавим кнопку забудете сочетание илиДавайте разберем приведенный выше добавить в MicrosoftФункции обработки системных параметровAbs
Он выдает число 1 Next. Нажимают Enter. возможностям, которые присутствуютВозвращает целое число, соответствующеедень годаAB, то данная процедура же, если аргумент FunctionSub запуска макроса прямо вообще его не в качестве примера Excel недостающие, но
CVErrМатематические функции секунд, которые прошлиЗдесь step — шаг.
Как начать
Теперь, когда уже запущена в новой версии месяцу в заданной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 выдает в
- шаг единичный. «Запись макроса». Это изменения посторонним лицом.
Возвращает заданное количество символовhBooleanЕсли перед объявлением процедуры
заданный пользователем. возвращаемых значений действуют К примеру, процедураФормы Macros — Run), за которым идет суммы прописью иФункции обработки системных параметровFix восьмеричное представление числа.Полученные результаты нужно сохранять действие означает завершение
Тем не менее из середины переданнойчас(True или False). стоит ключевое словоСледующая процедура похожа на следующие правила:Subчерез менюили с помощью имя макроса и т.д.
ErrorМатематические функцииФункции форматирования. Важнейшей из в ячейки с программки. Microsoft Office, а строки. Синтаксис функции:
Пример 2
n Основные операторы сравненияPrivate
только что рассмотренную,Тип данных возвращаемого значенияв VBA добавляетВид — Панели инструментов кнопки список аргументов (входныхМакросФункции обработки системных параметровInt них является Format.
номером (i,1). ТогдаДалее: также IBM LotusMid(минута Excel VBA перечислены, то данная процедура но на этот должен быть объявлен
заданное целое число — Формы (ViewМакросы (Macros) значений) в скобках.- это запрограммированнаяGetAllSettingsМатематические функции
Она возвращает значение
при каждом запуске
вновь переходят на строку
Symphony позволяют пользователю
строка
s в этой таблице: будет доступна только раз, вместо изменения в заголовке процедуры
(Integer) в каждую — Toolbars -
на вкладке Если аргументов нет, последовательность действий (программа,Функции обработки системных параметров
IsNumeric типа Variant с цикла с увеличением «Макросы»;
применять шифрование начального,
секундаОператор Действие для текущего модуля.
размера, применяется полужирное
Function
ячейку в выделенном Forms)Разработчик (Developer) то скобки надо процедура), записанная наGetSettingМатематические функции выражением, отформатированным согласно
i на величинув списке выбирают «Макрос кода и установку
Пример 3
началоПример:= Её нельзя будет начертание шрифта в. диапазоне. Передать процедуре
В Excel 2007 иили нажав ALT+F8. оставить пустыми. языке программирования VisualФункции обработки системных параметровLog инструкциям, которые заданы шага автоматически будет 1»;
пароля для его,DateAdd(«d», 32, «01/01/2015»)Равно вызвать, находясь в выделенном диапазоне ячеек.Переменная, которая содержит возвращаемое это число можно
новее — откройтеСохранить в…
Любой макрос должен заканчиваться Basic for ApplicationsIMEStatusМатематические функции в описании формата.
расти и номернажимают «Выполнить» (то же просмотра.длинадобавляет 32 дня<>
любом другом модуле Это пример процедуры значение, должна быть
при помощи аргумента, выпадающий список- здесь задается оператором (VBA). Мы можемФункции обработки системных параметровRnd
и пр. у строки. Таким действие запускается начатиемИменно с этими понятиями) к дате 01/01/2015Не равно или из рабочейSub названа так же, вот так:
Вставить (Insert) место, куда будет
End Sub
запускать макрос сколькоIsEmptyМатематические функцииИзучение свойств этих функций образом, произойдет оптимизация сочетания клавиш «Ctrl+hh»).
нужно разобраться тем,где и, таким образом,Меньше книги Excel.
, которой не передаются как и процедураSub AddToCells(i Asна вкладке
сохранен текст макроса,
. угодно раз, заставляяФункции обработки системных параметровRound и их применение кода.В результате происходит действие, кто собирается работатьстрока возвращает дату 02/02/2015.>
Пример 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 процедуры не нужны.
Решение задачи с использованием программирования на 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-функций
в шаблон, на цикле по всем этого языка понимает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 помогают создаватьМетоды — это команды, строка, аInStrA Or BFunction быть сделано с
иллюстрирует, как данные может быть несколько, стоимость (НДС) откроем и могут быть переходим ко второмуВ новых версиях (ExcelФункции работы с датамиLTrim резервируют. Рабочему листу какого-то условия. Не различные макросы в показывающие, что требуетсядлинаПринимает в качестве аргументов
возвратит, в которой ожидается процедурой передаются процедуре через все они перечисляются редактор VBA, добавим запущены в любой способу создания макросов, 2007 и новее)MonthNameФункции обработки строк присваивается новое название. обойтись без них Excel.
Способ 1. Создание макросов в редакторе Visual Basic
сделать. При написании– это количество целое число иTrue получение положительного аргументаFunction аргументы. Можно увидеть,
- в конце списка новый модуль через момент и в а именно… для этого нужноФункции работы с датами Mid Например, «Օтчет». и в VBA
- Циклы VBA помогают создавать кода в VBA символов, которые надо две строки. Возвращает, если для выполнения дальнейших, потому что процедура что тип данных, аргументов. меню любой книге.Макрорекордер сначала отобразить вкладкуNowФункции обработки строкДля написания программы автоматического Excel. Примеры программ, различные макросы. Предположим, их необходимо отделять извлечь, считая от позицию вхождения второйA операций. Если процедуре
Sub
возвращаемых процедурой, определёнАргументы в VBA могутInsert — ModuleПосле включения записи и- это небольшаяРазработчик (Developer)Функции работы с датамиPartition
заполнения шаблона, необходимо где дальнейший ход что имеется функция от объекта точкой. конца заданной строки. строки внутри первой,или передано не положительноене возвращает значение. как быть переданы процедуреи введем туда выполнения действий, которые программа, встроенная в. ВыбираемSecondФункции обработки строк выбрать обозначения. Они выполнения алгоритма выбирается, y=x + x2 Например, как будет
- Пример: начиная поиск сB значение, то дальнейшие Однако, процедурыDouble двумя способами: текст нашей функции: необходимо записать, запись Excel, которая переводитФайл — Параметры -Функции работы с датамиReplace будут использоваться для а не предопределен + 3×3 – показано в дальнейшем,Right(«абвгдежзиклмн», 4)
- позиции, заданной целымравны операции не могутSub(об этом говорятByValОбратите внимание, что в можно остановить командой любое действие пользователя Настройка ленты (FileTimeФункции обработки строк переменных: изначально, чаще всего
- cos(x). Требуется создать очень часто привозвращает строку «клмн»; числом.True быть выполнены, поэтому, не имеющие аргументов слова– передача аргумента отличие от макросовОстановить запись на язык программирования — Options -Функции работы с датамиRightNN– номер текущей строки используют конструкцию If
макрос для получения программировании в «Эксель»Right(«абвгдежзиклмн», 1)
Пример:, и возвратит пользователю должно быть и объявленные какAs Double
- по значению. Это функции имеют заголовок(Stop Recording) VBA и записывает Customize Ribbon)TimerФункции обработки строк таблицы; …Then (для сложных ее графика. Сделать
- используют команду Cells(1,1).Select.возвращает строку «н».InStr(1, «Вот искомое слово»,False
- показано сообщение обPublicпосле списка аргументов). значит, что процедуреFunction. получившуюся команду ви включаем вФункции работы с датамиRTrimTP и TF – случаев) If …Then это можно только, Она означает, чтоSecond «слово»), если ошибке и процедура(как будет показано
Также данный пример передаётся только значениевместоУправление всеми доступными макросами программный модуль. Если правой части окнаTimeSerialФункции обработки строк планируемый и фактический …END If. используя циклы VBA. необходимо выбрать ячейкуВозвращает целое число, соответствующеевозвращает число 13.A должна быть тут далее), будут доступны показывает, как результат (то есть, копия
Способ 2. Запись макросов макрорекордером
Sub производится в окне, мы включим макрорекордер флажокФункции работы с датамиSpace товарооборот;Рассмотрим конкретный случай. Предположим,За начальное и конечное с координатами (1,1) количеству секунд вInStr(14, «Вот искомое слово,и же завершена: для пользователей рабочего процедуры аргумента), и, следовательно,и непустой список которое можно открыть на запись, аРазработчик (Developer)TimeValueФункции обработки строкSF и SP – необходимо создать макрос значение аргумента функции т.е. A1. заданном времени. а вот ещеBFunction 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на вкладке то макрорекордер начнет
доступны основные инструменты
- Функции работы с датамиSplitIP и IF – координатами (1,1) было необходимо ввести константу выполнение означает очисткувозвращает значение 15.
- Примечание:. If sVAT_RateSub с именем процедуры. при выходе из
). После ввода кодаРазработчик (Developer) записывать команды вслед для работы сWeekdayName
- Функции обработки строк планируемый и фактически записано: — значение для содержимого выбранной ячейки.SqrАргумент-число может бытьNot
- Обратите внимание, что передвставлены в модульЕсли рассмотренная выше простая неё. наша функция становитсяили — в за каждым нашим макросами, в томФункции работы с датамиStr уровень издержек. 1, если аргумент положительный; шага изменения аргументаПрежде всего требуется создатьВозвращает квадратный корень числовой не задан, вОперация отрицания, логический оператор тем, как завершить в редакторе Visual
- процедураByRef доступна в обычном старых версиях Excel действием и, в числе и нужнаяYearФункции обработки строк
-
- Обозначим теми же буквами,0, если аргумент нулевой; и начальное значение файл и сохранить величины, переданной в таком случае поискНЕ выполнение процедуры
- Basic, то процедураFunction– передача аргумента окне Мастера функций — через меню итоге, мы получим нам кнопкаФункции работы с датамиStrComp но с «приставкой»-1, если аргумент отрицательный. для счетчика.
- его, присвоив имя аргументе. начинается с первого. Например, выражениеFunctionFormat_Centered_And_Boldвставлена в модуль по ссылке. То (Сервис — Макрос - макрос создающий отчетРедактор Visual BasicHexФункции обработки строк Itog накопление итога
Создание такого макроса дляВсе примеры макросов VBA и выбрав типПример: символа строки, заданной Not A–
Запуск и редактирование макросов
будет доступна для в редакторе Visual есть процедуре передаётсяВставка — Функция Макросы как если бы(Visual Basic Editor)Функции преобразования чисел вStrConv по данному столбцу. «Эксель» начинается стандартным Excel создаются по «Книга Excel сSqr(4) во втором аргументе
- возвратитVAT_Amount использования на рабочем Basic, то она фактический адрес размещения) в категории
- (Tools — Macro - он был написан : разные системы счисленияФункции обработки строк Например, ItogTP – способом, через использование
- той же процедуре, поддержкой макросов». возвращает значение 2; функции.True, в код вставлена листе книги Excel, может быть вызвана
Создание кнопки для запуска макросов
аргумента в памяти.Определенные пользователем (User Defined) Macros) программистом. Такой способК сожалению, интерфейс редактораOctString
касается столбца таблицы, «горячих» клавиш Alt которая представлена выше.
Затем необходимо перейти вSqr(16) Int, если встроенная VBA функция а процедура из других процедур Любые изменения, сделанные:: создания макросов не VBA и файлыФункции преобразования чисел в
Функции обработки строк озаглавленного, как «планируемый и F11. Далее В данном конкретном приложение VB, длявозвращает значение 4.Возвращает целую часть заданногоAMsgBox
Format_Centered_And_Sized VBA или использована с аргументом внутри
После выбора функции выделяемЛюбой выделенный в списке требует знаний пользователя справки не переводятся разные системы счисленияStrReverse товарооборот». записывается следующий код: случае код выглядит, чего достаточно воспользоваться
Time числа.равно, которая показывает пользователю– не будет на рабочем листе процедуры, будут сохранены ячейки с аргументами макрос можно запустить о программировании и
компанией Microsoft на
VarTypeФункции обработки строкИспользуя введенные обозначения, получаемSub program() как: комбинацией клавиш «Alt»Возвращает текущее системное время.
- Пример:False всплывающее окно с доступна, так как в книге Excel. при выходе из (с суммой, для кнопкой VBA и позволяет
- русский язык, поэтомуФункции преобразования чисел вTab формулы для отклонений.x= Cells(1, 1).Value (этаSub programm() и «F11». Далее:
UboundInt(5.79)
, или возвратит предупреждением. она имеет аргументы.Процедуру процедуры. которой надо посчитатьВыполнить пользоваться макросами как
Создание пользовательских функций на VBA
с английскими командами разные системы счисленияФункции обработки строк Если требуется осуществить команда присваивает xx1 = 1в строке меню, расположенномВозвращает верхний индекс измерениявозвращает результат 5.FalseУрок подготовлен для ВасВот простой способ запуститьFunctionПри помощи ключевых слов НДС) как в(Run) неким аналогом видеозаписи: в меню иCreateObjectTrim
расчет в % значение содержимого ячейкиx2 = 10 в верхней части заданного массива.Isdate, если командой сайта office-guru.ru (или выполнить) процедуруможно вызвать из
ByVal случае с обычной. включил запись, выполнил окнах придется смириться:Функции работы с объектамиФункции обработки строк имеем (F – с координатами (1,shag = 0.1 окна, нажимают наПримечание:ВозвращаетAИсточник: http://www.excelfunctions.net/VBA-Functions-And-Subroutines.htmlSub другой VBA процедурыили функцией:
Кнопка операци, перемотал пленкуМакросы (т.е. наборы командGetAutoServerSettingsTypeName P) / P 1))
planetaexcel.ru
i = 1
Ранее были рассмотрены процедуры VBA. В настоящей заметке рассмотрены функции VBА.[1] Функция — это процедура VBA, которая выполняет вычисления и возвращает значение. Функции можно использовать в коде VBA или в формулах Excel. Процедуру можно рассматривать как команду, которая выполняется пользователем или другой процедурой. С другой стороны, функция обычно возвращает отдельное значение (или массив) подобно функциям рабочих листов Excel и встроенным функциям VBA.
Рис. 1. Применение пользовательской функции в формуле рабочего листа
Скачать заметку в формате Word или pdf, примеры в архиве (политика безопасности провайдера не позволяет загружать файлы Excel с поддержкой макросов)
Excel содержит более 400 встроенных функций. Если этого количества недостаточно, можно создавать пользовательские функции с помощью VBA. Однако следует отметить, что функции VBA, используемые в формулах, обычно выполняются медленнее, чем встроенные функции Excel. Пользовательские функции отображаются в диалоговом окне Мастер функций наряду со встроенными функциями Excel.
Пример пользовательской функции
Начнем с примера – функции RemoveVowels (УдалитьГласные), которая принимает текстовый аргумент, удаляет все гласные буквы и возвращает текст, состоящий только из согласных.
Function RemoveVowels(txt) As String
'
Удаляет все гласные звуки из аргумента txt
Dim i As Long
RemoveVowels = "
"
For i = 1 To Len(txt)
If Not ucase(Mid(txt, i, 1)) Like "
[AEIOUАЕИОУЮЭЯ]"
Then
RemoveVowels = RemoveVowels & Mid(txt, i, 1)
End If
Next i
End Function
Код пользовательских функций, которые используются в формуле рабочего листа, вводите в обычном модуле VBA. Если вы поместите пользовательские функции в модуле Лист, в Пользовательской форме или в модуле ЭтаКнига, они не будут выполняться в формулах.
Функцию RemoveVowels можно использовать, например, в формуле в ячейке В1 (рис. 1) =RemoveVowels (А1). Вы также можете создавать вложенные пользовательские функции и сочетать их в формулах с обычными функциями Excel. Например, =ПРОПИСН(RemoveVowels(А1))
Пользовательские функции можно применять не только в формулах рабочего листа, но и в процедурах VBA. Например, процедура ZapTheVowels() сначала отображает окно для ввода текста пользователем, затем обрабатывает этот текст функцией RemoveVowels, и наконец использует встроенную функцию VBA MsgBox для отображения результатов (рис. 2). Первоначальные данные отображаются в заголовке окна сообщения.
Sub ZapTheVowels()
Dim UserInput As String
UserInput = InputBox("
Введите текст:"
)
MsgBox RemoveVowels(UserInput), vbInformation, UserInput
End Sub
Рис. 2. Применение пользовательской функции в процедуре VBA
Помните, что функции, используемые в формулах рабочего листа, — «пассивные». Они не могут изменять содержимое рабочего листа. Например, нельзя написать функцию, которая будет изменять цвет текста в ячейке в зависимости от значения этой ячейки. Функция возвращает значение, но не может выполнять операции над объектами.
Из этого правила имеется одно исключение. Вы можете изменить текст комментария ячейки с помощью пользовательской функции VBA:
Function ModifyComment(Cell As Range, Cmt As String)
Cell.Comment.Text Cmt
End Function
Например, можно ввести в ячейку В1 формулу =ModifyComment(А1,»Комментарий был изменен»). Функция не работает, если в ячейке А1 отсутствует комментарий.
Рассмотрим код функции RemoveVowels подробнее. Функция начинается с ключевого слова Function, а не Sub, после которого указывается название функции (RemoveVowels). Эта специальная функция использует только один аргумент (Txt), заключенный в скобки. Ключевое слово As String определяет тип данных значения, которое возвращает функция. (Excel по умолчанию использует тип данных Variant, если тип данных не определен.)
Вторая строка — простой комментарий (необязательный), который описывает выполняемые функцией действия. После комментария приведен оператор Dim, который объявляет переменную (i), применяемую в функции. Тип этой переменной — Long. Далее в качестве переменной используется имя функции. Как только функция завершает свое выполнение, возвращается текущее значение переменной, которое соответствует названию функции.
Следующие пять инструкций образуют цикл For-Next. Процедура циклически просматривает каждый символ введенного текста, создавая на их основе строку. Первая инструкция в цикле использует функцию VBA Mid, которая возвращает единственный символ строки ввода, а также преобразует этот символ в символ верхнего регистра. Затем этот символ сравнивается со списком символов с помощью оператора VBA Like (подробнее см. Оператор Like). Другими словами, значение выражения If будет True, если символ отличен от символов А, Е, I, O, U, А, Е, И, О, У, Ы, Э, Ю и Я. В подобных случаях символ добавляется к переменной RemoveVowels.
По завершении цикла из строки ввода удаляются все гласные буквы. Эта строка и является значением, возвращаемым функцией RemoveVowels. Процедура завершается оператором End Function. (Альтернативный код – RemoveVowels2, выполняющий ту же задачу приведен в модуле VBA приложенного Excel-файла.)
Синтаксис функции
Для объявления функции применяется следующий синтаксис (элементы аналогичны обычной процедуре; подробнее см. Работа с процедурами VBA).
[Public | Private][Static] Function имя ([список_аргументов])[As тип]
[инструкции]
[имя = выражение]
[Exit Function]
[инструкции]
[имя = выражение]
End Function
Значение всегда присваивается названию функции минимум один раз и, как правило, тогда, когда функция завершила выполнение. Создание пользовательской функции начните с создания модуля VBA (можно также использовать существующий модуль). Введите ключевое слово Function, после которого укажите название функции и список ее аргументов (если они есть) в скобках. Вы также можете объявить тип данных значения, которое возвращает функция, используя ключевое слово As (это делать необязательно, но рекомендуется). Вставьте код VBA, выполняющий требуемые действия, и убедитесь, что необходимое значение присваивается переменной процедуры, соответствующей названию функции, минимум один раз в теле функции. Функция заканчивается оператором End Function.
Имена функций подчиняются тем же правилам, что и имена переменных. Если вы планируете использовать функцию в формуле рабочего листа, убедитесь, что название не имеет форму адреса ячейки. Также не присваивайте функциям имена, которые соответствуют названиям встроенных функций Excel. Если область действия функции не задана, то по умолчанию подразумевается Public. Функции, объявленные как Private, не отображаются в диалоговом окне Мастер функций.
Функцию можно вызвать одним из следующих способов:
- вызвать ее из другой процедуры;
- включить ее в формулу рабочего листа;
- включить в формулу условного форматирования;
- вызвать ее в окне отладки VBE (Immediate). Этот метод обычно применяется на этапе тестирования (рис. 3).
Рис. 3. Вызов функции в окне отладки
В отличие от процедур, функции не отображаются в диалоговом окне Макрос (меню Разработчик –> Код –> Макросы; или Alt+F8).
Аргументы функций
Аргументы могут представляться переменными (в том числе массивами), константами, символьными данными или выражениями. Некоторые функции не имеют аргументов. Функции имеют как обязательные, так и необязательные аргументы.
Функции без аргументов
В Excel есть несколько встроенных функций, не имеющих аргументов, например, СЛЧИС, СЕГОДНЯ, ТДАТА. Несложно создать аналогичные пользовательские функции. Например:
Function User()
'
Возвращает имя пользователя
User = Application.UserName
End Function
При вводе формулы =User() ячейка возвращает имя текущего пользователя (рис. 4). Обратите внимание: при использовании функции без аргумента в формуле рабочего листа необходимо указать пустые скобки.
Рис. 4. Формула =User() возвращает имя текущего пользователя
Пользовательские функции ведут себя подобно встроенным функциям Excel. Обычно пользовательская функция пересчитывается тогда, когда это нужно, т.е. в случае изменения одного из аргументов функции. Однако вы можете выполнять пересчет функций чаще. Функция пересчитывается при изменении любой ячейки, если в процедуру добавлен оператор
Application.Volatile True
Метод Volatile объекта Application имеет один аргумент (True или False). Если функция выделена как volatile (изменяемая), она пересчитывается всякий раз, когда изменяется любая ячейка листа. При использовании аргумента False метода Volatile функция пересчитывается только тогда, когда в результате пересчета изменяется один из ее аргументов.
В Excel есть встроенная функция СЛЧИС. Но мне не слишком понравилось, что случайные числа изменяются при каждом пересчете рабочего листа. Поэтому я разработал функцию, которая возвращает случайные числа, не изменяющиеся при пересчете формул. Для этого была использована встроенная функция VBA Rnd:
Function StaticRand()
'
Возвращает случайное число, не изменяемое при пересчете формул
StaticRand = Rnd()
End Function
Значения, полученные с помощью этой формулы, никогда не изменяются. Но у пользователя остается возможность принудительного пересчета формулы с помощью комбинации клавиш <Ctrl+Alt+F9>.
Функция с одним аргументом
Допустим вам нужно подсчитать комиссионные, зависящие от объема продаж. Вычисления основываются на следующей таблице значений:
Рис. 5. Таблица комиссионных
Существует несколько способов вычислить комиссионные. Например, с помощью следующей формулы (если объем продаж поместить в ячейку D1):
=ЕСЛИ(И(D1>=0;D1<=9999,99);D1*0,08;ЕСЛИ(И(D1>=10000;D1<=19999,99);D1*0,105; ЕСЛИ(И(D1>=20000;D1<=39999,99);D1*0,12;ЕСЛИ(D1>=40000;D1*0,14))))
Эта формула неудачна по нескольким причинам. Во-первых, она сложна, ее нелегко набрать, и в дальнейшем редактировать. Во-вторых, значения строго определены в формуле, из-за чего ее сложно изменять. Гораздо лучше использовать ВПР (рис. 6).
Рис. 6. Использование функции ВПР для вычисления комиссионных
Еще лучше (тогда не нужно использовать таблицу соответствия) создать пользовательскую функцию:
Function Commission(Sales)
Const Tier1 = 0.08
Const Tier2 = 0.105
Const Tier3 = 0.12
Const Tier4 = 0.14
'
Вычисление комиссионных с продаж
Select Case Sales
Case 0 To 9999.99: Commission = Sales * Tier1
Case 10000 To 19999.99: Commission = Sales * Tier2
Case 20000 To 39999.99: Commission = Sales * Tier3
Case Is >= 40000: Commission = Sales * Tier4
End Select
End Function
После ввода в модуль VBA эту функцию можно использовать в формуле на рабочем листе или вызвать из других процедур VBA. При вводе в ячейку следующей формулы будет получен результат 3000:
=Commission(В2)
Используйте аргументы, а не ссылки на ячейки. Все применяемые в пользовательской функции диапазоны должны передаваться в качестве аргументов. Рассмотрим функцию, которая возвращает значение в ячейке А1, умноженное на 2.
Function DoubleCell()
DoubleCell = Range("
Al"
) * 2
End Function
Хотя эта функция работает, в некоторых случаях она выдает неправильный результат. Причина в том, что вычислительный механизм Excel не учитывает диапазоны, которые не передаются в качестве аргументов. Вследствие этого иногда перед возвратом функцией значения, не вычисляются все связанные величины. Следует также написать функцию DoubleCell, в качестве аргумента которой передается значение ячейки А1.
Function DoubleCell(cell)
DoubleCell = cell * 2
End Function
Функция с двумя аргументами
Представим, что менеджер, о котором речь шла выше, внедряет новую политику, разработанную для уменьшения текучести кадров: общая сумма комиссионных, подлежащих выплате, увеличивается на 1% за каждый год, который служащий проработал в компании. Изменим пользовательскую функцию Commission так, чтобы она принимала два аргумента. Новый аргумент представляет количество лет, отработанных сотрудником в компании. Назовем эту новую функцию Commission2:
Function Commission2(Sales, Years) As Single
'
Вычисление комиссионных с продаж на основе
'
длительности стажа
Commission2 = Commission(Sales) + _
(Commission(Sales) * Years / 100)
End Function
Функция с аргументом в виде массива
В качестве аргументов функции могут принимать один или несколько массивов, обрабатывать этот массив (массивы) и возвращать единственное значение. Функция, представленная ниже, принимает в качестве аргумента массив и возвращает сумму его элементов.
Function SumArray(List) As Double
Dim Item As Variant
SumArray = 0
For Each Item In List
If WorksheetFunction.IsNumber(Item) Then _
SumArray = SumArray + Item
Next Item
End Function
Функция Excel ЕЧИСЛО проверяет, является ли каждый элемент числом, прежде чем добавить его к общему целому. Добавление этого простого оператора проверки данных устраняет ошибки несоответствия типов при попытке выполнить арифметическую операцию над строкой.
Функция с необязательными аргументами
Многие встроенные функции Excel имеют необязательные аргументы. Пример — функция ЛЕВСИМВ, возвращающая символы с левого края строки. Она имеет следующий синтаксис:
ЛЕВСИМВ(текст, кол_символов)
Первый аргумент — обязательный, в отличие от второго. Если не указан второй аргумент, Excel предполагает значение 1.
Пользовательские функции, разработанные в VBA, также могут иметь необязательные аргументы. Необязательный аргумент вы зададите, если введете перед именем аргумента ключевое слово Optional. В списке аргументов необязательные аргументы определяются после всех обязательных. Например:
Function User2(Optional Uppercase As Variant)
If IsMissing(Uppercase) Then Uppercase = False
User2 = Application.UserName
If Uppercase Then User2 = UCase(User2)
End Function
Если аргумент равен False или опущен, то имя пользователя возвращается без каких-либо изменений. Если же аргумент функции True, то имя пользователя возвращается в символах верхнего регистра (с помощью VBA-функции Ucase). Обратите внимание на первый оператор функции — он содержит VBA-функцию IsMissing, которая определяет наличие аргумента. Если аргумент отсутствует, оператор присваивает переменной Uppercase значение False (задано по умолчанию).
Функция VBA, возвращающая массив
VBA содержит весьма полезную функцию с названием Array. Она возвращает значение с типом данных Variant, которое содержит массив (т.е. несколько значений). Если вы не знакомы с формулами массивов в Excel, предлагаю начать с Excel. Введение в формулы массива. Формула массива вводится в ячейку после нажатия <Ctrl+Shift+Entei>. Excel добавляет вокруг формулы скобки, чтобы указать, что это формула массива.
Функция MonthNames — простой пример применения функции Array в пользовательской функции.
Function MonthNames()
MonthNames = Array("
Январь"
, "
Февраль"
, "
Март"
, _
"
Апрель"
, "
Май"
, "
Июнь"
, "
Июль"
, "
Август"
, _
"
Сентябрь"
, "
Октябрь"
, "
Ноябрь"
, "
Декабрь"
End Function
Функция MonthNames возвращает горизонтальный массив названий месяцев. На рабочем листе выделите 12 ячеек, введите формулу =MonthNames() и нажмите <Ctrl+Shift+Enter>. Если необходимо сгенерировать вертикальный массив названий месяцев, выделите вертикальный диапазон, введите формулу =ТРАНСП(MonthNames()) и нажмите <Ctrl+Shift+Enter>.
Функция, возвращающая значение ошибки
В VBA содержатся встроенные константы для обозначения ошибок, которые должна возвращать пользовательская функция (эти значения — ошибки выполнения формул Excel, а не ошибки выполнения кода VBA):
- xlErrDivO (для ошибки #ДЕЛ/0!);
- xlErrNA (для ошибки #Н/Д);
- xlErrName (для ошибки #ИМЯ?);
- xlErrNull (для ошибки #ПУСТО!);
- xlErrNum (для ошибки #ЧИСЛО!);
- xlErrRef (для ошибки #ССЫЛ!);
- xlErrValue (для ошибки #ЗНАЧ!).
Ниже приведена преобразованная функция RemoveVowels (см. пример в начале). Конструкция If-Then применяется для выполнения альтернативного действия в случае, когда аргумент не является текстовым. Эта функция вызывает функцию Excel ЕТЕКСТ, которая определяет, содержит ли аргумент текст. Если ячейка содержит текст, то функция возвращает нормальный результат. Если же ячейка содержит не текст (или пуста), то функция возвращает ошибку #ЗНАЧ!
Function RemoveVowels3(txt) As Variant
'
Удаляет все гласные буквы из аргумента Txt
'
Возвращает ошибку #ЗНАЧ!, если аргумент — не строка
Dim i As Long
RemoveVowels3 = "
"
If Application.WorksheetFunction.IsText(txt) Then
For i = 1 To Len(txt)
If Not UCase(Mid(txt, i, 1)) Like "
[AEIOUАЕИОУЮЭЯ]"
Then
RemoveVowels3 = RemoveVowels3 & Mid(txt, i, 1)
End If
Next i
Else
RemoveVowels3 = CVErr(xlErrValue)
End If
End Function
Обратите внимание, что был изменен тип данных для возвращаемого функцией значения. Поскольку функция может возвращать что-то еще, кроме строки, тип данных был изменен на Variant.
Функция с неопределенным количеством аргументов
Существует возможность создавать пользовательские функции, имеющие неопределенное количество аргументов. Примените в качестве последнего (или единственного) аргумента массив и добавьте перед ним ключевое слово ParamArray (ParamArray относится только к последнему аргументу в списке аргументов процедуры. Он всегда имеет тип данных Variant и всегда является необязательным аргументом). Следующая функция возвращает сумму всех аргументов, в качестве которых может выступать, как одно значение (ячейка), так и диапазон.
Function SimpleSum(ParamArray arglist() As Variant) As Double
Dim cell As Range
Dim arg As Variant
For Each arg In arglist
For Each cell In arg
SimpleSum = SimpleSum + cell
Next cell
Next arg
End Function
Отладка функций
При использовании формулы на рабочем листе для тестирования функции происходящие в процессе выполнения ошибки не отображаются в знакомом диалоговом окне сообщений. Формула просто возвращает значение ошибки (#ЗНАЧ!). К счастью, это не представляет большой проблемы при отладке функций, так как всегда существует несколько обходных путей.
- Поместите в важных местах функцию MsgBox, чтобы контролировать значения отдельных переменных.
- Протестируйте функцию, вызвав ее из процедуры, а не в формуле рабочего листа. Ошибки в процессе выполнения отображаются обычным образом.
- Определите точку остановки в функции и просмотрите функцию пошагово. При этом можно воспользоваться всеми стандартными инструментами отладки. Чтобы добавить точку остановки, поместите курсор в операторе, в котором вы решили приостановить выполнение, и выберите команду Debug –> Toggle Breakpoint (Отладка –> Точка остановки) или нажмите <F9>.
- Используйте в программе один или несколько временных операторов Print (Отладка, Печать), чтобы отобразить значения в окне Immediate редактора VBA. Например, чтобы проконтролировать циклически изменяемое значение, используйте следующий метод:
Рис. 7. Используйте окно отладки для отображения результатов при выполнении функции
В данном случае значения двух переменных, Ch и i, выводятся в окне отладки (Immediate) всякий раз, когда в программе встречается оператор Debug.Print. Встаньте курсором в любое место процедуры Test() и нажмите F5. На рис. 7 показан результат для случая, когда функция принимает аргумент TusconArizona.
Использование метода MacroOptions
Можно воспользоваться методом MacroOptions объекта Application, который позволяет включить в состав встроенных функций Excel разработанные вами функции. Этот метод позволяет:
- добавить описание функции (начиная с версии Excel 2010;
- указать категорию функции;
- добавить описание аргументов функции.
Sub DescribeFunction()
Dim FuncName As String
Dim FuncDesc As String
Dim FuncCat As Long
Dim Arg1Desc As String, Arg2Desc As String
FuncName = "
Draw"
FuncDesc = "
Содержимое случайной ячейки диапазона"
FuncCat = 5 '
Ссылки и массивы
Arg1Desc = "
Диапазон, который содержит значения"
Arg2Desc = "
(не обязательный) Если False или отсутствует, _
функция Rnd не пересчитывается. "
Arg2Desc = Arg2Desc & "
Если True, функция Rnd пересчитывается "
Arg2Desc = Arg2Desc & "
при любом изменении на листе."
Application.MacroOptions _
Macro:=FuncName, _
Description:=FuncDesc, _
Category:=FuncCat, _
ArgumentDescriptions:=Array(Arg1Desc, Arg2Desc)
End Sub
На рис. 8 показаны диалоговые окна Мастер функций и Аргументы функции после выполнения процедуры DescribeFunction().
Рис. 8. Вид диалоговых окон Мастер функций и Аргументы функции для пользовательской функции
Процедуру DescribeFunction()следует вызывать только один раз. После ее вызова информация, связанная с функцией, сохраняется в рабочей книге. Но если вы модифицировали процедуру, повторите ее вызов.
Если вы не укажете категорию функции с помощью метода MacroOptions, пользовательская функция рабочего листа появится в категории Определенные пользователем диалогового окна Мастер функций. В таблице (рис. 9) перечислены номера категорий, которые можно использовать в качестве значений аргумента Category метода MacroOptions. Обратите внимание, что некоторые из этих категорий (от 10 до 13) обычно не отображаются в диалоговом окне Мастер функций. Если же отнести одну из пользовательских функций в подобную категорию, она появится в диалоговом окне.
Рис. 9. Номера категорий функций
Использование надстроек для хранения пользовательских функций
При желании можно сохранить часто используемые пользовательские функции в файле надстройки. Основное преимущество такого подхода заключается в следующем: функции могут быть применены в формулах без спецификатора имени файла. Предположим, у вас есть пользовательская функция ZapSpaces; она хранится в файле Myfuncs.xlsm. Чтобы применить ее в формуле другой рабочей книги (отличной от Myfuncs.xlsm), необходимо ввести следующую формулу: =Myfuncs.xlsm!ZapSpaces(А1:С12).
Если вы создадите надстройку на основе файла Myfuncs.xlsm и эта надстройка будет загружена в текущем сеансе работы Excel, то ссылку на файл можно пропустить, введя следующую формулу: =ZapSpaces(А1:С12). Создание надстроек будет рассмотрено отдельно.
Потенциальная проблема, которая может возникнуть из-за использования надстроек для хранения пользовательских функций, связана с зависимостью рабочей книги от файла надстроек. Если вы передаете рабочую книгу сотруднику, не забудьте также передать копию надстройки, которая содержит требуемые функции.
Использование функций Windows API
VBA может заимствовать методы из других файлов, которые не имеют ничего общего с Excel или VBA, например, файлы DLL (Dynamic Link Library — динамически подключаемая библиотека), которые используются Windows и другими программами. В результате в VBA появляется возможность выполнять операции, которые без заимствованных методов находятся за пределами возможностей языка.
Windows API (Application Programming Interface — интерфейс прикладного программирования) представляет собой набор функций, доступных программистам в среде Windows. При вызове функции Windows из VBA вы обращаетесь к Windows API. Многие ресурсы Windows, используемые программистами Windows, можно получить из файлов DLL, в которых хранятся программы и функции, подсоединяемые в процессе выполнения программы, а не во время компиляции.
Прежде чем использовать функцию Windows API, ее необходимо объявить вверху программного модуля. Если программный модуль — это не стандартный модуль VBA (т.е. модуль для UserForm, Лист или ЭтаКнига), то API-функцию необходимо объявить, как Private.
Объявление API-функции имеет некоторую сложность — функция должна объявляться максимально точно. Оператор объявления указывает VBA следующее:
- какую API-функцию вы используете;
- в какой библиотеке расположена API-функция;
- аргументы API-функции.
После объявления API-функцию можно использовать в программе VBA.
Рассмотрим пример API-функции, которая отображает имя папки Windows (с помощью стандартных операторов VBA эту задачу порой выполнить невозможно). Для начала объявим API-функцию:
Declare PtrSafe Function GetWindowsDirectoryA Lib "
kernel32"
_
(ByVal lpBuffer As String, ByVal nSize As Long) As Long
Эта функция, имеющая два аргумента, возвращает название папки, в которой установлена операционная система Windows. После вызова этой функции путь к папке Windows будет храниться в переменной lpBuffer, а длина строки пути — в переменной nSize.
Следующий пример отображает результат в окне сообщения:
Sub ShowWindowsDir()
Dim WinPath As String * 255
Dim WinDir As String
WinPath = Space(255)
WinDir = Left(WinPath, GetWindowsDirectoryA _
(WinPath, Len(WinPath)))
MsgBox WinDir, vbInformation, "
Windows Directory"
End Sub
В процессе выполнения процедуры ShowWindowsDir отображается окно сообщения с указанием расположения папки Windows.
Иногда требуется создать оболочку (wrapper) для API-функций. Другими словами, вы создадите собственную функцию, использующую API-функцию. Такой подход существенно упрощает использование API-функции. Ниже приведен пример такой функции VBA:
Function WindowsDir() As String
'
Название папки Windows
Dim WinPath As String * 255
WinPath = Space(255)
WindowsDir = Left(WinPath, GetWindowsDirectoryA _
(WinPath, Len(WinPath)))
End Function
После объявления этой функции можно вызвать ее из другой процедуры: MsgBox WindowsDir(). Можно также использовать эту функцию в формуле рабочего листа: =WindowsDir().
Внимание! Не удивляйтесь сбоям в системе при использовании в VBA функций Windows API. Заранее сохраните свою работу перед тестированием.
Определение состояния клавиши <Shift>
Предположим, вы написали макрос VBA, который будет выполняться с помощью кнопки на панели инструментов. Необходимо, чтобы этот макрос выполнялся по-другому, если пользователь после щелчка на кнопке удерживает клавишу <Shift>. Чтобы узнать о нажатии клавиши <Shift>, можно использовать API-функцию GetKeyState. Функция GetKeyState сообщает о том, нажата ли конкретная клавиша. Функция имеет один аргумент, nVirtKey, который представляет код интересующей вас клавиши.
Ниже приведена программа, которая выявляет, что при выполнении процедуры обработки события Button_Click была нажата клавиша <Shift>. Обратите внимание, что для определения состояния клавиши <Shift> используется константа (принимающая шестнадцатеричное значение), которая затем применяется как аргумент функции GetKeyState. Если GetKeyState возвращает значение меньше 0, это означает, что клавиша <Shift> нажата; в противном случае клавиша <Shift> не нажата. Аналогичную проверку можно устроить для клавиш Ctrl и Alt (рис. 10).
Рис. 10. Проверка нажатия клавиш Shift, Ctrl и Alt
Код функции VBA можно найти в приложенном Excel-файле
Работа с функциями Windows API может быть довольно сложной. Во многих книгах по программированию перечислены операторы объявления API-функций с соответствующими примерами. Как правило, можно просто скопировать выражения объявления и использовать функции, не вникая в их суть. Большинство VBA-программистов в Excel рассматривают API-функции как панацею для решения большинства задач. В Интернете вы найдете сотни вполне надежных примеров, которые можно скопировать и вставить в собственную программу.
В текстовом файле содержатся объявления и константы Windows API. Можно открыть этот файл в текстовом редакторе и скопировать соответствующие объявления в модуль VBA.
[1] По материалам книги Джон Уокенбах. Excel 2010. Профессиональное программирование на VBA. – М: Диалектика, 2013. – С. 287–323.