- •Программное обеспечение информационных технологий
- •Системное по
- •Составные части операционной системы
- •Командный язык
- •Файловая система
- •Прикладное по
- •Инструментальное по
- •Общие характеристики языков высокого уровня
- •Основы программирования
- •Информационное обеспечение информационных технологий
- •Использование информационных технологий в управлении предприятиями
- •Интернет технологии
- •Internet-технологии в бизнесе
- •Юридическое обеспечение ит Тенденции развития ит Приложение
- •Visual Studio .Net - открытая среда разработки
- •Синтаксические описания
- •Переменные
- •Типы данных в vba
- •Преимущества объявления переменных
- •Объявление переменных: Dim и Static
- •Арифметические операторы и работа с числовыми переменными
- •Конкатенация
- •Преобразование типов данных
- •Функции проверки типа данных
- •Встроенные математические функции
- •Строковые функции
- •Пользовательские процедуры и функции
- •Пользовательская процедура
- •Пользовательская функция
- •Пользовательские типы данных
- •Константы
- •Массивы
- •Одномерные массивы
- •Цикл For - Next
- •Многомерные массивы
- •Вложенные циклы For-Next
- •Динамические массивы
- •Дополнительные команды работы с массивами
- •Цикл с предусловием
- •Цикл с постусловием
- •Принятие решений: If-Then-Else
- •Сравнение с использованием Like и Is
- •Принятие решений: Select Case
- •Оператор безусловного перехода
- •Работа с файлами
Синтаксические описания
Синтаксис языка программирования — это правила написания программ.
Рассмотрим пример — возьмем из справочной системы описание команды. Мы пока не будем вдаваться в смысл ключевых слов (перед нами — описание оператора цикла), приведенных здесь, остановимся на основных частях описания.
For counter = start To end [Step step]
[statements]
[Exit For]
[statements]
Next [counter]
В синтаксических описаниях VBA жирным шрифтом выделены ключевые слова языка, курсивом даны названия переменных и других элементов языка. В квадратных скобках располагаются необязательные элементы – то есть такие элементы, без описания которых можно обойтись. Например, в приведенном описании блоки [statements] будут содержать в себе "полезную нагрузку" цикла – операторы, которые будут выполняться многократно, однако цикл будет работать и без них.
Элементы, которые допускают альтернативный выбор, разделяются знаком "|". Например, такая запись: "one | two" обозначает "one или two".
Ниже мы будем останавливаться на существенно важных особенностях тех или иных конструкций. Если вам понадобятся подробности — вы сможете найти их в справке к VBA.
Теперь рассмотрим понятие переменной — важнейшее понятие в любом языке программирования.
Переменные
Переменная — это именованная область памяти, где могут храниться различные данные, которые можно изменять во время выполнения программы. Переменные— это одна из основ любой программы. В них можно сохранять введенную пользователем информацию, их можно использовать для накопления данных, обработанных в программе и так далее. Если бы не было переменных — программирования не существовало бы.
У переменной есть несколько важнейших характеристик. Первая — имя переменной. Используя имя, мы можем обращаться к переменной в программе. Вторая характеристика — это тип данных, которые могут храниться в переменной. Тип определяет характер данных, которые мы можем хранить в переменной. Например, это могут быть числовые данные (возраст пользователя) и строковые данные (имя пользователя).
Давая переменным имена, следует придерживаться следующих правил.
Имя переменной должно состоять из букв и цифр, причем оно должно начинаться с буквы.
Имя не может быть длиннее 255 символов
Имя не должно содержать специальных знаков (#, $, % и т.д.) и пробелов.
В качестве имен нельзя использовать зарезервированные слова VBA (например – if, dim, for и т.д.).
При именовании переменных старайтесь пользоваться латинскими буквами. Иначе возможны проблемы при работе ваших программ на различных версиях Office.
Например, такие имена переменных выглядят вполне корректно: str_Name, num_Age, str_Name1, num_Item2 и т.д. Обратите внимание на префиксы, которыми мы снабдили имена переменных. Это признак особого стиля именования переменных. Он очень напоминает стиль именования элементов управления, который мы рассматривали выше.
Типы данных в vba
Тип данных определяет важнейшие свойства переменной. А именно, следующее:
что может храниться в переменной (текст, число, некоторые другие виды данных);
размер памяти, необходимый для хранения переменной (измеряется в байтах);
операции, которые можно производить с переменной (например, невозможно извлечь квадратный корень из слова "Привет" так как эта операция не определена для строковых данных);
Вы уже можете предположить как минимум два типа данных, которые могут хранить переменные — строковые и числовые. На самом деле список типов данных VBA гораздо обширнее.
В следующей таблице вы найдете информацию об основных типах данных VBA.
Таблица Типы данных в VBA |
|||
Тип данных |
Размер, байт |
Описание |
Диапазон значений |
Variant |
16 (числа) 22+длина строки (строки) |
Может хранить данные любых типов |
|
Integer |
2 |
Целое число |
от -32768 до 32767 |
Long |
4 |
Длинное целое |
от -2147483648 до 2147483647 |
Single |
4 |
Число с плавающей запятой обычной точности до значения и для положительных |
Для отрицательных: от -3.402823E38 до -1.401298E-45 Для положительных: от 1.401298E-45 до 3.402823E38 |
Double |
8 |
Число с плавающей запятой двойной точности, для отрицательных значений и для положительных |
Для отрицательных от -1.79769313486231E308 до -4.94065645841247E-324 Для положительных: от 4.94065645841247E-324 до 1.79769313486232E308 |
Byte |
1 |
Байт |
от 0 до 255 |
Currency |
8 |
Денежный формат |
от -922,337,203,685,477.5808 до 922,337,203,685,477.5807 |
Decimal |
14 |
Масштабируемое целое |
29-значное число с 28 знаками справа от запятой |
Boolean |
2 |
Логический |
True или False |
Date |
8 |
Дата и время |
от 1 января 100 г. до 31 декабря 9999 г. |
Object |
4 |
Ссылка на объект |
Различные виды объектов |
String |
Зависит от длины строки |
Строка |
|
В VBA существует немало типов данных. Может показаться, что нет ничего удобнее типа данных Variant. Однако надо учесть, что за универсальность типа Variant приходится платить производительностью и системными ресурсами. Чем больше места требуется для хранения переменной — тем ниже скорость работы с ней.
Если вы хотите, чтобы ваши программы работали как можно быстрее — выбирайте типы данных, которые используют для хранения вашей информации минимум системных ресурсов. Если вы сомневаетесь, хватит ли размерности выбранного типа данных для решения ваших задач — возьмите более емкий тип.
Как правило, для работы с дробными числами и различных вычислений используют тип данных Double. Для переменных, которые используются в циклах, счетчиках — Integer или Long. В работе со строками используют String. Объектные переменные имеют самые разные типы, которые определяются объектами, для обращения к которым они создаются. В небольших проектах вполне оправдано использование переменных типа Variant – это не слишком замедлит работу. Однако, если размер проекта растет или вы нуждаетесь в ускорении ресурсоемких вычислений – подходите к выбору типов данных ответственно.
Если при объявлении переменной не указывать ее тип — он автоматически устанавливается в Variant. Объявляя переменную без указания типа, вы пользуетесь преимуществами работы с объявленными переменными, и, в то же время, можете гибко использовать переменную для хранения различных типов данных (например – чисел с плавающей запятой и целых чисел). Такой подход — объявление переменных без указания типа — допустим при создании небольших проектов, а так же — на начальном этапе работы над достаточно масштабными программами, когда вы не знаете точно, какой тип данных понадобится для той или иной переменной.
Выше мы уже говорили о венгерской нотации как о способе именования объектов. Те же правила действуют и для переменных. Префикс имени обычно говорит о типепеременной. В следующей таблице приведены некоторые префиксы.
Таблица Префиксы и типы переменных |
|
Префикс имени переменной |
Пояснения |
s, str |
Строковая переменная |
n, num |
Числовая переменная (существует множество числовых типов данных, название каждого из которых может быть использовано в качестве префикса, например, int для Integer, dbl для Double и т.д.) |
b, bool |
Логическая переменная |
O, obj |
Объектная переменная |
Для работы с переменными можно использовать два подхода. При первом мы выбираем имя переменной и используем ее в программе без каких-либо подготовительных действий. Такая переменная приобретет тип Variant. Второй подход предусматривает объявление переменных перед использованием.