- •Государственное учреждение образования
- •Б28 Система программирования vba : лаб. Практикум / н.В. Батин. – Минск : Ин-т подгот. Науч. Кадров Нац. Акад. Наук Беларуси, 2011. – 70 с.
- •Содержание
- •Введение
- •Лабораторная работа №1 Основы программирования на языке vba
- •1.1 Основные этапы работы с программами на vba в Excel
- •1.2 Простейший пример программы на языке vba
- •1.3 Типы данных. Объявление переменных и констант
- •1.3.1 Типы данных
- •1.3.2 Объявление переменных
- •1.3.3 Объявление констант
- •1.3.4 Область видимости переменных
- •1.3 Оператор If
- •1.4 Массивы
- •1.5 Цикл до. Оператор For
- •1.6 Цикл пока. Операторы While и Until
- •1.7 Безусловный переход. Оператор goto
- •1.8 Подпрограммы
- •1.9 Функции
- •1.10 Область видимости процедур
- •1.11 Варианты заданий
- •Лабораторная работа №2 операции с ячейками и рабочими листами ms excel в программах на vba
- •2.1 Основные способы ссылок на ячейки рабочего листа Excel
- •2.2 Основные способы ссылок на диапазоны ячеек рабочего листа Excel. Определение размеров диапазона ячеек
- •2.3 Основные операции с рабочими листами ms Excel
- •2.4 Примеры решения задач с использованием диапазонов ячеек
- •2.9 Варианты заданий
- •Лабораторная работа №3 элеменТы управления в программах на vba
- •3.1 Размещение элементов управления на рабочем листе Excel
- •3.2 Пример разработки программы с использованием элементов управления: кнопки, переключатели, счетчики, флажки, текстовые поля
- •3.3 Пример разработки программы с использованием элементов управления: списки
- •3.4 Варианты заданий
- •Лабораторная работа №4 пользовательские форМы в программах на vba
- •4.1 Создание пользовательской формы в Excel
- •4.2 Примеры программ с использованием пользовательских форм
- •4.3 Варианты заданий
- •Лабораторная работа №5 пользовательские формы с развитыми элементами управления в программах на vba
- •5.1 Список из нескольких колонок
- •5.2 Список с возможностью выбора нескольких элементов
- •5.3 Составление списка в программе
- •5.4 Поля ввода ячеек
- •5.5 Варианты заданий
- •Лабораторная работа №6 разработка программ на vba для работы с текстовыми данными
- •6.1 Подготовка среды vba для работы с файлами
- •6.2 Ввод данных из файла
- •6.3 Вывод данных в файл
- •6.4 Обмен данными между двумя файлами
- •6.5 Функции обработки строк
- •6.5 Варианты заданий
- •Список использованных источников
- •Система программирования vba
Лабораторная работа №1 Основы программирования на языке vba
Цель работы – Изучение основных операторов и реализации основных конструкций программирования в языке VBA.
1.1 Основные этапы работы с программами на vba в Excel
Для подготовки и выполнения программы на языке VBA требуется выполнить следующее:
в Excel выбрать из меню команду Сервис – Макрос – Редактор Visual Basic;
в появившемся окне выбрать из меню команду Insert – Module. Создается модуль, т.е., упрощенно говоря, открывается окно, в котором можно вводить текст программы.
В начале модуля может указываться инструкция Option Explicit. Если она указана, то все переменные, используемые в программе, необходимо будет объявлять в операторе Dim (подробнее об этом см. в разделе 1.3).
В некоторых случаях, в зависимости от настройки среды VBA, инструкция Option Explicit указывается в начале модуля автоматически. Если программист желает использовать переменные, не объявляя их в операторе Dim, то инструкцию Option Explicit необходимо удалить.
Для запуска программы на выполнение необходимо выбрать из меню команду Run – Run Sub/UserForm.
1.2 Простейший пример программы на языке vba
Пример 1.1 – Программа, возводящая указанное число a в указанную степень b.
Sub primer1_1()
‘Первый пример программы на VBA
a = InputBox(“Введите основание: ”)
b = InputBox(“Введите показатель степени: ”)
x = a^b ‘Возведение в степень
MsgBox(“Результат равен ” & x)
End Sub
Здесь слово Sub обозначает начало процедуры; ее имя в данном случае – primer1_1. Программа на языке VBA всегда состоит из одной или нескольких процедур (в данном случае – из одной).
Символ ‘ (одиночная кавычка) обозначает начало комментария. Текст комментария может быть любым.
InputBox – функция для ввода значения переменной. Строка a = InputBox (“Введите основание: ”) означает, что вводится значение переменной a; при этом на экран выводится сообщение “Введите основание:”. Строка x = a^b – оператор присваивания: вычисляется значение правой части (в данном случае переменная a возводится в степень b), и результат присваивается переменной, указанной в левой части (в данном случае – переменной x). Строка MsgBox(“Результат равен ” & x) означает, что на экран выводится сообщение “Результат равен ” и значение переменной x.
Примечание – Знак & в функции MsgBox предназначен для сцепления нескольких элементов данных, которые требуется вывести на экран, в данном примере – строки “Результат равен” и переменной x. Аналогично знак & может использоваться в функции InputBox (примеры такого использования будут приведены далее). Перед знаком & и после него обязательно должны быть указаны пробелы.
В одной строке можно разместить несколько операторов языка VBA. Для этого они разделяются символами «двоеточие». Так, программу из примера 1.1 можно было записать, например, следующим образом:
Sub primer1_1()
‘Первый пример программы на VBA
a = InputBox(“Введите основание: ”) : b = InputBox(“Введите показатель степени: ”)
x = a^b : MsgBox(“Результат равен ” & x) ‘Возведение в степень и вывод результата
End Sub
В рассмотренном примере использована процедура, называемая подпрограммой. Такая процедура начинается со слова Sub. В программе на VBA всегда имеется хотя бы одна процедура-подпрограмма. Кроме того, в языке VBA имеется еще один вид процедур – функции. Процедура-функция начинается со слова Function. Использование таких процедур будет рассмотрено в подразделе 1.9.