Следующая статья: Начинаем изучать VBA - с чего начать?
Содержание
- Тип, определяемый пользователем
- Приведение и преобразование типов
- Таблица «Функции преобразования типов»
Тип, определяемый пользователем
VBA позволяет пользователю определять свои собственные типы данных. Определенный пользователем тип нужен, когда одной переменной необходимо обозначить несколько связанных по смыслу элементов данных, причем эти элементы данных могут быть разных типов. Пример структурного типа приведен на рисунке. Тип Book состоит из трех элементов: Title (название книги) имеет тип String, Content – динамический массив строкового типа, содержащий название глав книги, Author (автор книги), который, в свою очередь, тоже является структурным типом, состоящим из двух простых элементов – Name (имя) и Birthday (день рождения).
Пример структурного типа, определяемый пользователем
Для объявления такого типа данных используется оператор Туре:
Туре <имяТипа>
…<имяЭлемента1> [([<размер1>])] As <типДанных1>
…<имяЭлемента2> [([<размер2>])] As <типДанных2>
End Туре
Элементами типа могут быть простые переменные и массивы встроенных типов, а также переменные и массивы других определенных пользователем типов. Типы Book и Person могут быть объявлены следующим образом:
Type Person
Name As String
Birthday As Date
End Type
Type Book
author As Person
Title As String
Content () as String
End Type
Объявление переменных структурного типа выполняется так же, как и обычных переменных:
Dim MyBook As Book, Editor As Person
Обращение к элементу структурного типа выполняется следующим образом:
MyBook.Title=«Учебник»
ReDim MyBook.Content (0 to 10)
MyBook.Content(0)=«От автора»
Перечисляемый тип
Еще одним видом структурного типа данных является перечисляемый тип. Элементами перечисляемого типа являются все его значения. Определяется перечисляемый тип с помощью оператора Enum:
Enum <имяТипа> <имяЗначения1> [=<Константа>] <имяЗначения2>
[=<Константа>]
End Enum
По умолчанию все значения типа перенумеровываются целыми числами, начиная с 0, но можно самостоятельно указать константное целое значение для значений типа.
Примером перечисляемого типа данных является встроенный логический тип Boolean.
Enum Boolean False
True End Enum
Над каждым типом данных определено некоторое множество простейших действий, называемых операциями. Язык VBA имеет большое количество встроенных функций для работы с каждым типом данных.
Приведение и преобразование типов
Приведением называется автоматическое преобразование значения одного типа данных в эквивалентное значение другого типа в процессе выполнения операций с данными. Приведение выполняется, если операнды (данные, участвующие в операции) имеют разные типы. При этом результат операции будет иметь тот тип, к которому приводится один из операндов. Например, складываются два числа – целое (Integer) и вещественное (Double). В процессе этой операции целое число приводится к вещественному (Double), и результат будет иметь тип Double. Обратное преобразование (Double в Integer) может привести к потере данных. На рисунке приведена схема, показывающая, значения каких типов к каким типам приводятся без потери информации.
Схема преобразования данных без потерь
VBA имеет также набор функций, которые можно использовать для явного преобразования типов данных в операциях. Эти функции приведены в таблице «Функции преобразования типов».
Таблица «Функции преобразования типов»
| Функции | Возвращает действие | Возвращаемый тип |
|---|---|---|
| Asc (S) | Возвращает число кода символа, соответствующее первой букве строки S. Буква «А», например, имеет код символа 65 | Integer |
| CBool(N) | Возвращает Вооlеаn-эквивалент численного выражения N | Boolean |
| Format (Е, S) | Возвращает строку, содержащую значение, представленное выражением Е, в формате в соответствии с инструкциями, содержащимися в S | String |
| Str(N) | Возвращает строку, эквивалентную численному выражению N | String |
| Val(S) | Возвращает численное значение, соответствующее числу, представленному строкой S, которая должна содержать только цифры и одну десятичную точку, иначе VBA не может преобразовать ее в число. Если VBA не может преобразовать строку в S, то функция Val возвращает 0 | Variant |
| CByte(E) | Возвращает численное значение типа Byte (от 0 до 255); Е - любое допустимое численное или строковое выражение, которое может быть преобразовано в число | Byte |
| CCur(E) | Возвращает численное значение типа Currency; Е - любое допустимое численное или строковое выражение, которое может быть преобразовано в число | Currency |
| CDate(E) | Возвращает значение типа Date. Е может быть любым допустимым выражением (строкой или числом), представляющим дату в диапазоне 1/1/100-12/31/9999 включительно | Date |
| CDbl(E) | Возвращает численное значение типа Double; Е - любое допустимое численное или строковое выражение, которое может быть преобразовано в число | Double |
| Cint(E) | Возвращает численное значение типа Integer; Е - любое допустимое численное или строковое выражение, которое может быть преобразовано в число | Integer |
| CLng(E) | Возвращает численное значение типа Long; Е - любое допустимое численное или строковое выражение, которое может быть преобразовано в число | Long |
| CSng(E) | Возвращает численное значение типа Single; Е - любое допустимое численное или строковое выражение, которое может быть преобразовано в число | Single |
| CStr(E) | Возвращает значение типа String; Е - любое допустимое численное или строковое выражение | String |
| CVar(E) | Возвращает значение типа Variant; Е - любое допустимое численное или строковое выражение | Variant |
| Chr(N) | Возвращает строку из одного символа, соответствующего коду символа N, который должен быть числом между 0 и 255 включительно. Код символа 65, например, возвращает букву «А» | Символ |
Видео: «Это не то, о чем вы подумали»
Невыдуманные ситуации, иногда случающиеся с каждым из нас

