
- •2. Блок ввода-вывода.
- •3. Логический блок.
- •4 . Блоки начала и конца блок-схем
- •5.Соединительные блоки
- •Однострочный if.
- •Блочный if.
- •Как назначить макрос кнопке размещенной на рабочем месте так, чтобы щелчок на этой кнопке заставлял выполнить нужный макрос?
- •Создание собственного кода программы.
- •Первая программа на vba. Воспользуемся третьим сценарием. По пунктам запишем наши действия.
- •Как запустить нашу программу из редактора vbа на выполнение?
- •Как из окна редактора попасть на рабочий лист?
- •Где хранятся программы?
- •Циклические алгоритмы.
- •Рассмотрим циклы for … next
- •Найти произведение целых чисел от к до м с шагом 2
- •Циклы с условием do … loop
- •Продолжение знакомства с редактором vba
- •Модули и процедуры.
- •Процедура – подпрограмма
- •Процедура – функция
- •Создание процедур-подпрограмм..
- •Процедура подпрограммы.
- •Как вызвать процедуры из других программ?
- •Передача аргументов в подпрограммы(по ссылке и по значению). Способ1 -Передача по ссылке.
- •Способ2.-Передача по значению.
- •Необязательные параметры в подпрограммах.
- •Процедура функция.
- •Объявления переменных и их области видимости
- •Объявление переменных.
- •Область видимости переменной
- •2) Переменная уровня модуля ( уровня контейнера )
- •Работаем с приложением Excel и его объектами.
- •Объектная модель Excel.
- •Объект Application( приложение в целом).
- •Объект Workbook(рабочая книга)
- •Основные методы объекта workbook
- •Объект Worksheet (Рабочий лист).
- •Основные методы объекта worksheet.
- •Основные свойства рабочих листов
- •Объект Range (диапазон)
- •Основные свойства объекта Range
- •7) Font - шрифт
- •Циклы вида With … Еnd With.
- •Пример.
- •Основные методы объекта Range
- •С объектом Selection можно работать точно так, как с объектом Range: те же свойства и те же методы.
- •Функция Format()
- •Еще раз о функциях val, inputbox Функция Val()
- •Функция InputBox().
- •Задача: проверка на «пустоту».
- •Отладка программ (debugging) Виды ошибок:
- •1)Синтаксические;
- •2)Во время выполнения программы;
- •3)Логические.
- •Точки останова(breakpoints).
- •Пошаговое выполнение программы.
- •Работа со справкой.
- •Окно отладки (Immediate).
- •Окно контрольных значений
- •Массивы
- •Нединамические массивы.
- •Динамические массивы.
- •Ввод, вывод одномерных массивов.
- •Введение массива с помощью функции InputBox (ввод «вручную»).
- •2)Введение массива с помощью генератора случайных чисел
- •Вывод массива.
- •1)Вывод массива в окно отладки
- •2)Вывод массива на рабочий лист
- •3)Вывод массива в окно сообщений
- •Пример1. Найти максимальный элемент в массиве
- •Пример2. Сортировка (упорядочивание) одномерного массива.
- •Двумерные массивы (таблицы или матрицы).
- •Ввод /вывод двумерного массива.
- •1)Ввод с помощью функции Input Box (ввод вручную)
- •2)Ввод с помощью генератора случайных чисел
- •Особенности ввода-вывода двумерных массивов на рабочий лист при работе с vba (excel)
- •Ввод массива
- •Вывод массива на рабочий лист.
- •Обращение к массивам при работе с подпрограммами.
- •Vvod b,n,m,k ‘вызов подпрограммы ввода массива
- •Примеры решения задач, связанных с двумерными массивами.
- •Задача1.Найти сумму элементов под побочной диагональю квадратной матрицы размера n×n.
- •Функции, определяющие границы индексов массивов.
- •Элементы визуального программирования.
- •Панель управления «формы» .
- •Экранные формы.
- •Для того, чтобы вставить форму в наше приложение необходимо выполнить команды:
- •Свойства формы.
- •Этапы разработки визуальных программ.
- •2) Написание кода.
- •Первая визуальная программа «Здравствуй ,мир!»
- •Первый этап ( настраивание свойств формы и элементов управления).
- •Второй этап ( написание кода).
- •Как запустить наше приложение из окна редактора vba?
- •Как сделать так, чтобы наша форма запускалась с рабочего листа?
- •Программа “Курс доллара”.
- •События формы.
- •Переключатель (Option Button)
- •Флажок или индикатор (Check Box)
- •Полоса прокрутки (ScrollBar)
- •Пример1. Программа «скорость».
- •Пример 2. «Утоляем жажду».
- •Элемент управления «рисунок» (Image)
- •Элемент управления «список» (ListBox)
- •Поле со списком, или комбинированный список(Combobox)
- •Пример использования.
- •Static – объявление переменной статической.
- •Дополнительные элементы управления.
- •Работа с файлами последовательного доступа
- •Открыть файл последовательного доступа можно в трёх режимах:
- •Открытие файла.
- •Закрытие файла ( оператор close).
- •Формат оператора input:
- •Операторы вывода в файл print и write
- •Формат функции eof
- •Input#1, X ‘считываем очередной элемент массива
- •Литература.
Модули и процедуры.
Код VBA должен где-то храниться и это “где-то” называют модулем. Различают 2 типа модулей: стандартные и модули класса. Мы будем рассматривать стандартные модули.
Определение. Модуль – это совокупность объявлений и процедур, хранящихся как единое целое.
Объявления помогают указать программе, с какого типа данными она будет иметь дело, (объявить наши переменные целого типа, вещественного, текстового и так далее). .При этом, в зависимости от типа переменной, программа по- разному выделяет память для их хранения. Кроме того, при объявлении переменных мы указываем область видимости нашей переменной, то есть в каких модулях и программах будет “видно” нужное нам значение, где мы можем использовать значение той или другой переменной.
Определение. Процедура - это набор команд, предназначенных для решения конкретной задачи. Например: процедура для нахождения корня квадратного или кубического уравнения, нахождения определенного интеграла на заданном промежутке и так далее.
Мы рассматриваем 2 типа процедур:
Процедура – подпрограмма
Процедура – функция
Отметим, что каждая из процедур хранится в модуле. В одном модуле может храниться несколько процедур. Одну сложную задачу можно разбить на ряд более простых, для каждой из которых подготовить процедуру и протестировать ее на правильность выполнения. После того, как процедуры созданы, в нашей основной программе нужно лишь правильно вызвать их, чтобы сделать отведенную им работу. Правильный вызов процедуры эквивалентен помещению соответствующего кода в тело программы.
Создание процедур-подпрограмм..
При создании процедур мы должны пройти следующие этапы:
1)Создать модуль, где процедура будет храниться.
2)Выделить место, где будут располагаться операторы процедуры, т.е. указать, где начинается и где заканчивается процедура. При этом мы обязательно укажем, как наша процедура будет называться,
3)Написать код процедуры.
Замечание: При создании макроса первые два пункта выполняются автоматически: автоматически создавался модуль, куда затем записывался код макроса.
Для того, чтобы процедуру создать с нуля поступим следующим образом:
1) войдем в редактор VBA (Alt+F11)
2)
Вставка
модуль
3) Для вставки процедуры::
а)в окне модуля ввести:
SUB <имя процедуры>
END SUB
или
б)Вставка
процедура(
Insert
Procedura)
В появившемся окне даём процедуре имя ( например, Оксана), и указываем область определения (Public-Общая)
В модуле появляется код:
Public SUB Оксана()
END SUB
Процедура подпрограммы.
Полный синтаксис подпрограммы процедуры следующий:
[Public
Private]
[Static] SUB-<имя> ([Список формальных
параметров])
<действия>
End sub
Первая строка называется заголовком процедуры;
Вторая называется телом процедуры. В ней идут <объявления> и <операторы>;
Тренья строка END SUB называется окончанием процедуры..
Замечание.
1)Квадратные скобки указывают на то, что соответственные ключевые слова не обязательны, и могут быть опущены.
2)Имя процедуры должно содержать не более 255 символов, начинаться с буквы и кроме букв может содержать цифры и символы подчеркивания.
Слова Private (личный), Public (общий) предназначены для того, чтобы указать, где данная процедура «будет доступной для использования».
Public-процедуру можно использовать в любом модуле нашего проекта, в то время как Private делает видимой процедуру только в том модуле, в котором она написана.
Отметим, что если слова Public и Private пропущены, то описываемая подпрограмма имеет статус подпрограммы типа Public, то есть, видна во всем проекте.
Список формальных параметров.
Через символ «,» задаются переменные, с которыми работает данная процедура. Ниже, среди операторов и объявлений будет указано, как, по каким формулам необходимо обрабатывать наши формальные параметры. Параметры называются формальными, потому что мы опишем, как с ними работать, не выясняя, какие конкретно значения при этом имеются в виду.
Отметим, что формальные аргументы не имеют никакого отношения к переменным, которые имеют те же имена в основной программе.