Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Введение примеры по VBA.doc
Скачиваний:
11
Добавлен:
22.09.2019
Размер:
1.99 Mб
Скачать

3.2. Работа с различными типами данных Тип, определяемый пользователем

      VBA позволяет пользователю определять свои собственные типы данных. Определенный пользователем тип нужен, когда одной переменной необходимо обозначить несколько связанных по смыслу элементов данных, причем эти элементы данных могут быть разных типов. Пример структурного типа приведен на рис. 27. Тип Book состоит из трех элементов: Title(название книги) имеет тип String, Content– динамический массив строкового типа, содержащий название глав книги, Author(автор книги), который, в свою очередь, тоже является структурным типом, состоящим из двух простых элементов – Name(имя) и Birthday(день рождения).

       Рис. 27.Пример структурного типа, определяемый пользователем         Для объявления такого типа данных используется оператор Туре:

      Туре <имяТипа>       …<имяЭлемента1> [([<размер1>])] As <типДанных1>       …<имяЭлемента2> [([<размер2>])] As <типДанных2>       End Туре

      Элементами типа могут быть простые переменные и массивы встроенных типов, а также переменные и массивы других определенных пользователем типов. Типы Book и Person (см. рис. 27) могут быть объявлены следующим образом:

      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) может привести к потере данных. На рис. 28 приведена схема, показывающая, значения каких типов к каким типам приводятся без потери информации.  

       Рис. 28.Схема преобразования данных без потерь         VBA имеет также набор функций, которые можно использовать для явного преобразования типов данных в операциях. Эти функции приведены в табл. 11.          Таблица 11