Общие положения
Основной задачей офисного программирования является создание документа.
В данном контексте "документ" понимается как объектв объектно-ориентированном программировании и представляет совокупность данных разного типа и программ, обрабатывающих эти данные.
Под документами Office понимают документы разных типов - рабочие книги Excel, документы Word, базы данных Access, презентации PowerPoint. С любым из этих документов связываются и данные и программы.
VBA поддерживается следующая структура программы.
На высшем уровне иерархии стоит приложение, в котором может быть создано несколько проектов.
Программный проект – часть документа, которая хранится вместе с документом и не может быть отделена от него. Невозможно создать независимый от документа проект на VBA. Каждому документу (или шаблону) соответствует свой проект. Каждый проект связан со своим документом (шаблоном).
Проект представляет собой набор программных модулей, связанных с основным документом приложения.
Программный модуль имеет жесткую структуру и вне зависимости от его типа (модуль, модуль класса, модуль формы…) включает в себя Раздел объявлений переменных уровня модуля (General Declarations section) и ряд подпрограмм (процедур).
Раздел объявлений идет первым и автоматически отделяется чертой от раздела процедур. Область действия этих переменных распространяется на модуль, но может быть и расширена.
Каждая подпрограмма в модуле может быть либо функцией Function, либо процедурой Sub. Так сложилось, что в литературе по VBA подпрограмму называют процедурой и говорят, что в языке VBA два типа процедур – процедуры Sub и процедуры Function (либо просто функции).
Определение процедуры Sub имеет следующий синтаксис:
Sub имя процедуры ([ список аргументов ])
‘ тело процедуры
End Sub
Список аргументов должен соответствовать передаваемым параметрам при вызове процедуры. В случае если процедуре параметры не передаются, список аргументов отсутствует (пустые круглые скобки).
Процедура без параметров называется макросом.
Макрос в Excel может быть создан автоматически макрорекодером.
Макрорекодер – транслятор действий пользователя на язык программирования. Результатом действия макрорекодера является создание макроса.
В Microsoft Excel программный код может храниться:
· в рабочих книгах (workbooks) - в текущей или личной книге макросов.
Код сохраняется с рабочей книгой и становится доступным, когда пользователь открывает ее.
По умолчанию Excel помещает макрос в модуль активной рабочей книги.
При желании можно записать его либо в новой рабочей книге (откроется пустая новая книга) либо в личной книге макросов. Личная книга макросов записана в файле Personal.xlsb, который хранится в папке XLStart. Загрузка книги происходит после запуска Excel и, соответственно, код доступен всегда при работе с Microsoft Excel. Данная книга скрыта, поэтому при обычной работе не видна. Файл Personal.xlsb не существует до тех пор, пока не будет записан в нее первый макрос.
· в шаблонах (templates)
Если вы сохраните рабочую книгу как шаблон, то код, созданный в ней, будет сохранен в шаблоне Microsoft Excel, В дальнейшем вы сможете создавать новые рабочие книги на базе этого шаблона. Когда Вы создаете книгу на базе шаблона, Microsoft Excel копирует шаблон в рабочую книгу, при этом копируется и находящийся в нем код.
В отличие от документа Word, который связан со своим шаблоном, Microsoft Excel не связан с шаблоном, т.е. любые изменения, сделанные в шаблоне, не отразятся на рабочих книгах, ранее созданных на этом шаблоне.
· в надстройках (add-ins)
Сохраняя рабочую книгу как надстройку, вы сохраняете ее с расширением.xlam. Затем для расширения возможностей Microsoft Excel, вы можете подгружать созданные надстройки.
Знакомство с интерфейсом пользователя в разных версиях MS Office
Рассмотрим четыре версии MS Excel, которые в настоящее время используются наиболее широко – Excel 97-2003, Excel 2007, Excel 2010 и Excel 2013 – различающиеся интерфейсом пользователя.
Группа Excel 97-2003 включает в себя версии Excel 97, Excel 2000, Excel 2002 и Excel 2003. Интерфейс пользователя осуществляется посредством меню и пиктографического меню.
В версиях Excel 2007, Excel 2010 и Excel 2013 интерфейс пользователя существенно изменился. Строка меню отсутствует и заменена лентой с вкладками, на которых расположены кнопки пиктографического меню, причем сгруппированы они совершенно иначе, чем в предыдущих версиях.
Ниже приведены примеры интерфейса табличного процессора версий Excel 97-2003, Excel 2007, Excel 2010 и Excel 2013.
а). Excel 97-2003
б). Excel 2007
в). Excel 2010
г). Excel 2013
Рис.1. Интерфейсы табличного процессора в разных версиях MS Excel
Интерфейс Редактора Visual Basic во всех версиях одинаков.