Телефон: +7 (495) 649-0526

Функции в Visual Basic (VBA) - создание и их запуск

Картинка к странице

Следующая статья:

Содержание

Описание функции

Function <имяФункции> (<аргумент1>, <аргумент2>, …) [As

<типЗначение>]

<оператор1>

<оператор2>

<имяФункции>=<возвращаемоеЗначение>

End Function

Кроме того что ключевое слово Sub заменяется на Function, в теле функции обязательно присутствует оператор присваивания имени функции какого-нибудь значения. Это значение и возвращается функцией. В заголовке функции может быть описан тип возвращаемого значения. Если этот тип не указан, функция возвращает значение Variant.

Рассмотрим два примера объявления подпрограмм и функций

Объявление процедуры инициализации массива

Sub Init (arr() As Integer)

Dim i As Integer, str As String

For i * LBound(arr) To UBound(arr)

str="Введите количество книг на полке № " & I

arr(i)=InputBox(str) 'функция ввода строки

Next I

End Sub

Объявление функции, подсчитывающей сумму любого числа аргументов

Function SummaVar(ParamArray varArg() As Variant) As Integer

Dim intSum As Integer, numb As Variant

For Each numb In varArg 'цикл по всем элементам массива

intSum=intSum + numb 'по умолчанию инициируется в 0

Next numb

SummaVar=intSum 'присвоение возвращаемого значения

End Function

Вызов подпрограмм и функций

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

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

Оператор вызова подпрограммы может использоваться в двух формах:

<имя Процедуры><список фактических параметров>

или

Call <имя Процедуры> (<список фактических параметров>).

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

Вызов функции имеет следующий вид

<имя переменной>=<имя функции>(<список фактических параметров>).

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

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

Dim intShelfs (I To 30) As Integer

Dim intS As Integer

Init intShelfs инициируем массив intShelfs

intS=SummaVar(1.2, 3.4, 5.6, 7.8, 9)'суммируем целые числа

Пример.

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

Процедуры и функция выполняют следующие действия:

  • первая процедура производит суммирование двух первых введенных значений a и b;
  • вторая процедура производит умножение третьего и четвертого введенных значений c и d;
  • функция вычисляет выражение a+b-c*d.

Технология выполнения

  • Откройте приложение Word, сохраните документ и перейдите в редактор VBA.
  • Создайте форму.
  • Пропишите обработчик события кнопки Счет.

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

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

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

Форма примера в режиме конструктора и в рабочем состоянии

Форма примера в режиме конструктора и в рабочем состоянии

Листинг примера

Dim a, b, c, d, k, m, h As Integer

Sub summ()

a=Val(TextBox1.Text)

b=Val(TextBox2.Text)

k=a + b

End Sub

Sub umn()

c=Val(TextBox3.Text)

d=Val(TextBox4.Text)

m=c * d

End Sub

Function prim() As Integer

Call summ

Call umn

prim=k – m

End Function

Private Sub CommandButton1_Click()

Call summ

Call umn

' переменные a и b являются глобальными для запуска функции prim, где k, m являются локальными переменными в соответствующих процедурах

h=prim(a, b)

Label8.Caption=«сумма a + b =» & k

Label9.Caption=«произведение c * d =» & m

Label10.Caption="значение функции a+b-c*d= " & h

End Sub

  • Откомпилируйте программу.
  • Запустите форму на выполнение.

Пример.

Создать программу, которая, используя данные, считанные из текстовых полей формы, выполняет вычисление значений двух выражений: y=sin(a + b ) + 5 и z=tg(c + + 3) – cos(3 * d ), где a, b, c, d – значения переменных, введенных в соответствующие текстовые поля. Данные значения y и z вычисляются в соответствующих процедурах (процедуре) или функциях. Основной блок программы сравнивает полученные значения, и об этом выдается сообщение на форму.

Форма примера в рабочем состоянии

Форма примера в рабочем состоянии

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

Видео: «Девушка играет в реальное GTA»

Девушка играет в реальное GTA
Интересное в интернете: Очень удобно. Ооо доступное жилье краснопольская как купить квартиру! Только здесь

Статья: Функции в Visual Basic (VBA) - создание и их запуск

Раздел: VBA программирование (office)

Сайт: SD Company » Все разделы статей

Последнее изменение: 2010.11.17 в 00:28

Теги: как использовать функции, vba

Следующая статья:

Макросы VBA - как создать и запустить
Макросы VBA - как создать и запустить
Описание основных наборов инструкций, при помощи которых создаются и запускаются макросы в офисных приложениях
Правила создания идентификаторов
Правила создания идентификаторов
Описаны основные правила при создании идентификаторов для различных платформ баз данных
Работа над созданием команды
Работа над созданием команды
Чтобы добиться качественного выполнения работы и достижения поставленных целей, нужно в процесс формирования команды вовлекать всех ее участников
Этапы работы по созданию команды
Этапы работы по созданию команды
Когда положено начало переменам, вместе с командой необходимо разработать план изменений не меньше чем на три месяца
Как происходит VBA программирование и расчеты
Как происходит VBA программирование и расчеты
В данной статье описывается создание шаблона табличного документа средствами VBA
Like оператор в Visual Basic (VBA)
Like оператор в Visual Basic (VBA)
Описание оператора Like в языке программирования vba и его функциональность и способы применения
Каким было сетевое общение раньше
Каким было сетевое общение раньше
Сетевые системы, ставшие доступными для всех, поражали воображение пользователей, так что поначалу никто и не задумывался, к чему это может привести