Студопедия

КАТЕГОРИИ:


Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748)

Оформление функций-процедур

Подпрограммы, их назначение и классификация

Программы и подпрограммы

 

 

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

Существует два вида процедур:

1. Подпрограмма – представляет собой определенный набор операторов, составленный пользователем и расположенный отдельно от основной программы.

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

1. аргументы, используемые функцией;

2. действия, выполняемые функцией;

3. значение, возвращаемое функцией.

Функции, создаваемые с помощью VBA, имеют различное применение, например, в Excel и Word. В Excel можно использовать функции VBA для расширения коллекции встроенных функций рабочих листов. Другие host-приложения VBA, такие как Access, также позволяют применять создаваемые VBA-функции для расширения и улучшения встроенной коллекции функций.

Отличие функции от подпрограммы состоит в том, что:

– функция обязательно должна возвращать (передавать результат вычисления) результат в основную программу;

– имя функции должно иметь спецификатор типа для определения типа самой функции.

Процедуры характеризуются следующими основными свойствами:

1. процедуры могут использовать локальные переменные – переменные, которые не зависят от одноименных переменных основной программы; эти переменные существуют и используются только внутри процедуры (одноименные переменные в основной программе и в процедуре – это разные переменные)

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

 

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

Функция-процедура имеет следующий синтаксис:

 

Function Name ([ Arglist ]) [ As Type ]

'VBA Statements

[ Name = expression ]

End Function

 

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

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

Туре – тип возвращаемого значения функции. Если это поле опускается, результат, который возвращает функция-процедура, имеет тип Variant.

Необязательный элемент синтаксиса Name = expression представляет присваивание функции, которое указывает, какое значение должна возвращать функция. Хотя эта часть функции является необязательной, следует всегда включать оператор присваивания в функции-процедуры. Объявление функции заканчивается ключевыми словами End Function.

Даже если функция не имеет аргументов, как VBA-функции Now, Date и Time, в объявлении функции необходимо использовать пустые круглые скобки, например:

 

Function ThisBookName()

 

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

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

Пример 38. Простая функция-процедура LenTrim

 

Dim tstr As String

Dim test As Integer

Sub stroka()

tstr = InputBox("Введите тестируемое выражение", "Запрос задачи")

test = LenTrim(tstr)

gg = MsgBox(test, vbOKOnly, "Ответ")

End Sub

Function LenTrim(tstr)

LenTrim = Len(Trim(tstr))

End Function

 

 

 

<== предыдущая лекция | следующая лекция ==>
Лекция № 30. Пример 36. Заменить элементы, находящиеся на диагоналях квадратной матрицы на нули | Создание определенных пользователем функций для Excel
Поделиться с друзьями:


Дата добавления: 2014-01-04; Просмотров: 693; Нарушение авторских прав?; Мы поможем в написании вашей работы!


Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет



studopedia.su - Студопедия (2013 - 2025) год. Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав! Последнее добавление




Генерация страницы за: 0.008 сек.