ПГУТИ
ОФИСНОЕ ПРОГРАММИРОВАНИЕ
Ссылки

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
Функции преобразования типов

Функция
Возвращает действие
Возвращаемый тип
Asc (S) Возвращает число кода символа, соответствующее первой букве строки S. Буква "А", например, имеет кол символа 65 Integer
CBool (N) Возвращает Boolean-эквивалент численного выражения N Boolean
Format (E,S) Возвращает строку, содержащую значение, представленное выражение E, в формате в соответствии с инструкциями, содержащимися в S String
Str (N) Возвращает строку, эквивалентную численному выражению N String
Val (S) Возвращает численное значение, соответствующее числу, представленному строкой S, которая должна содержать только цифры и одну десятичную точку, иначе VBA не может преобразовать строку в S, то функция Val возвращает 0 Variant
СByte (E) Возвращает численное значение типа Byte (от 0 до 255); E - любое допустимое численное или строковое выражение, которое может быть преобразовано в число Byte
CСur (Е) Возвращает численное значение типа Currency; E - любое численное или строковое выражение, которое может быть преобразовано в число Currency
CDate (E) Возвращает значение типа Date. Е - может быть любым допустимым выражением (строкой или числом), представляющим дату в диапазоне 1/1/100 - 31/12/9999 включительно Date
CDbl (E) Включает целочисленное значение типа Double; E - любое допустимое численное или строковое выражение, которое может быть преобразованно в число Double
CIint (E) Возвращает численное значение типа Integer; E -любое допустимое численное или строковое выражение, которое может быть преображовано в число Integer
CLng (E) Возвращает численное значение типа Long; E - любое допустимое численное или строковое выражение, которое может быть преображовано в число Long
CSng (E) Возвращает численное значение типа Single; E - любое допустимое численное или строковое выражение, которое может быть преображовано в число Single
CStr (E) Возвращает численное значение типа String; E - любое допустимое численное или строковое выражение String
CVar (E) Возвращает численное значение типа Variant; E - любое допустимое численное или строковое выражение Variant
Chr (N) Возвращает строку из одного символа, соответствующего коду символа N, который должен быть числом между 0 и 255 включительно. Код символа 65, например возвращает букву "А" Символ


Операции со строками

Для данных типа String существует только одна операция – конкатенация (объединение). Например, результатом операции конкатенации трех строковых значений «Петр» & " " & «Иванович» будет строка «Петр Иванович». Возможно также использование другого оператора для операции конкатенации, например: «десяти» + «тысячник». Разница между этими выражениями состоит в том, что в первом случае операндами могут быть значения любого типа (они просто будут преобразовываться в строковые), а во втором – оба операнда должны иметь тип String.
Для работы со строками существует большое количество функций (табл. 12).

Таблица 12
Функции работы со строками

Функция
Описание
Пример
Len (str) Определяет длинну строки Из а = len("Персонажи") следует а = 9
Left (<строка>, <длина>) Выделяет из аргумента <строка> указанное количество символов слева Left("1234string", 4) = "1234"
Right (<строка>, <длина>) Выделяет из аргумента <строка> указанное количество символов справа Right("1234string", 6) = "string"
Mid (<строка>, <старт> [,<длина>]) Выделяет из аргумента <строка>подстроку с указанным числом символов, начиная с позиции <старт> Mid ("12345678", 4, 3) = "456"
Mid (<строка>, <старт>) Выделяется подстрока от позиции <старт> до конца строки Mid ("12345678", 4) = "45678"
LTrim (<строка>) Удаляет пробелы в начале строки LTrim(" печать") = "печать"
RTrim (<строка>) Удаляет пробелы в конце строки RTrim("печать ") = "печать"
Trim (<строка>) Удаляет пробеы в начале и в конце строки Trim(" печать ") = "печать"
InStr ([<старт>,] <строка1>, <строка2> [,<сравнение>]) Производит поиск подстроки в строке. Возвращает позицию первого вхождения строки <строка2> в строку <сторока1>, <старт> - позиция, с которой начинается поиск. Если этот аргумент пропущен, поиск начинается с начала строки

InStr("C:\Temp\test.mdb", "Test") = 9

Если искомая строка не находиться в указанной строке, функция возвращает 0

InStrRev ([<старт>,] <строка1>, <строка2> [,<сравнение>]) Ищет подстроку в строке, но начинает с конца строки и возвращает позицию последнего вхождения подстроки. Необязательный аргумент <сравнение> определяет тип сравнения двух строк  
Replace (<строка>, <строкаПоиск>, <строкаЗамена>) Позволяет заменить в строке одну подстроку другой. Этафункция ищет все вхождения аргумента <строкаПоиск> в аргументе <строка> и заменяет их на <строкаЗамена>  


Для сравнения строковых значений можно использовать обычные операторы сравнения числовых значений, так как при сравнении символов сравниваются их двоичные коды.

Для сравнения строковых значений также применяется оператор Like, который позволяет обнаруживать неточное совпадение, например выражение «Входной сигнал» Like «Вход*» будет иметь значение True, так как сравниваемая строка начинается со слова «Вход». Символ звездочка (*) в строке заменяет произвольное число символов. Другие символы, которые обрабатываются оператором Like в сравниваемой строке:
? – любой символ (один);
#– одна цифра (0–9);
[<список>] – символ, совпадающий с одним из символов списка;
[!<список>] – символ, не совпадающий ни с одним из символов списка.

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

Split (<строка> [,<разделитель>]) – преобразует строку в массив подстрок. По умолчанию в качестве разделителя используется пробел. Данную функцию удобно использовать для разбиения предложения на слова. Однако можно указать в этой функции любой другой разделитель.
Например, Split(3, «Этo тестовое предложение») возвращает массив из трех строковых значений: «Это», «тестовое», «предложение».

Join (<массивСтрок> [,<разделитель>]) – преобразует массив строк в одну строку с указанным разделителем.

Filter(<массивСтрок>,<строкаПоиск>[,<включение>] [,<сравнение>]) – просматривает массив строковых значений и ищет в нем все подстроки, совпадающие с заданной строкой.

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

Еще три функции обеспечивают преобразование строк:
LCase(<строка>) – преобразует все символы строки к нижнему регистру, например функция

LCase(«ПОЧTA») возвращает строку «почта»;

UCase(<строка>) – преобразует все символы строки к верхнему регистру;

StrConv(<строка>,<преобразование>) – выполняет несколько типов преобразований строки в зависимости от второго параметра. Этот параметр описывается встроенными константами, например функция StrConv(«poccия»,VbProperCase) возвращает значение «Россия».

И последние две функции генерируют строки символов:

Space(<число>) – создает строку, состоящую из указанного числа пробелов;

String(<число>,<символ>) – создает строку, состоящую из указанного в первом аргументе числа символов. Сам символ указывается во втором аргументе.

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

1 метка: сообщается длина строки, введенной в первое текстовое поле (1 строка);
2 метка: преобразует все символы третьего текстового поля (3 строка) в заглавные буквы;
3 метка: выводит вместе содержание первого и второго текстовых полей (1 и 2 строки).

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



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

Private Sub CommandButton1_Click()
Dim a As String
Dim b As String
Dim c As String
Dim k As String
Dim d As String
Dim n As Integer
a = TextBox1.Text
n = Len(a)
Label7.Caption = «длина первой строки равна» & n & « символам»
c = TextBox3.Text
k = Ucase(с)
Label8.Caption = k
b = TextBox2.Text
d = a + " " + b
Label9.Caption = d
End Sub

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

© 2010 ПГУТИ
Главная | Теория | Практика | Вопросы к зачету | Словарь терминов
Hosted by uCoz