- •Оглавление
- •Введение
- •1. Объекты ms Excel
- •1.1. Объекты, их свойства и методы
- •1.1.1. Свойства: присвоение и использование значений
- •1.1.1.1. Присвоение значений
- •1.1.1.2. Использование значений
- •1.1.2. Примеры использования методов рабочей книги Excel
- •1.1.2.1. Вызов метода
- •1.1.2.2. Передача аргумента в метод
- •1.2. Ссылки на одиночные объекты и объекты из семейств
- •1.2.1. Различия между одиночными объектами и объектами из семейств
- •1.2.2. Семейства как объекты
- •1.2.3. Ссылка на объект
- •1.3. Иерархия объектов ms Excel
- •1.3.1. Иерархическая структура
- •1.3.2. Доступ к объектам через свойства и методы
- •1.4. Объект Application
- •1.4.1. Свойства объекта Application
- •1.4.2. Методы объекта Application
- •1.5. Объект Workbook и семейство Workbooks
- •1.5.1. Свойства объекта Workbook и семейства Workbooks
- •1.5.2. Методы объекта Workbook и семейства Workbooks
- •1.5.3. Функции, используемые для работы с файлами и папками
- •1.5.4. Функция MsgBox
- •1.5.5. Функция InputBox
- •1.6. Объект Worksheet
- •1.6.1. Свойства объекта Worksheet и семейства Worksheets
- •1.6.2. Методы объекта Worksheet и семейства Worksheets
- •1.7. Объект Range
- •1.7.1. Свойства объекта Range
- •1.7.2. Методы объекта Range
- •2. Использование переменных в vba
- •2.1. Допустимые имена
- •2.2. Типы данных переменных vba
- •2.3. Описание переменной
- •2.4. Использование переменных
- •2.5. Преимущества переменных
- •2.6. Объектные переменные
- •2.6.1. Задание объектной переменной
- •2.6.2. Объектные переменные общего типа
- •2.6.3. Объектные переменные конкретных типов
- •2.6.4. Преимущества объектных переменных
- •2.7. Неявное описание переменных и тип Variant
- •2.8. Обязательное описание переменных
- •2.9. Типы данных по умолчанию
- •2.10. Пользовательские типы данных
- •3. Массивы vba
- •3.1. Размерность массива
- •3.2. Объявление массива
- •3.3. Использование массива
- •3.4. Номер первого элемента и границы массива
- •3.5. Динамические массивы
- •3.6. Сохранение данных в динамическом массиве при изменении последней размерности
- •3.7. Пять функций для работы с массивами
- •4. Константы
- •5. Вызов одной программы из другой
- •5.1. Фрагментирование кода
- •5.2. Передача данных при вызове программы
- •6. Использование функций в vba
- •7. Область видимости переменных, констант, подпрограмм и функций
- •7.1. Область видимости переменных
- •7.1.1. Переменные уровня процедуры
- •7.1.2. Переменные уровня модуля
- •7.1.3. Переменные уровня проекта
- •7.1.4. Сохраняемые переменные
- •7.1.5. Область видимости подпрограмм и функций
- •7.1.6. Сохраняемые подпрограммы и функции
- •8. Управляющие структуры
- •8.1. Управляющая инструкция If-Then-Else
- •8.2. Управляющая инструкция Select Case
- •8.3. Управляющая инструкция For-Next
- •8.4. Управляющая инструкция For-Each-Next
- •8.4.1. Инструкция For-Each-Next с многомерными массивами
- •8.4.2. Инструкция For-Each-Next с семействами
- •8.5. Управляющая инструкция While-Wend
- •8.6. Управляющая инструкция Do-Loop
- •9. Инструкция With
- •10. Встроенные функции vba
- •10.1. Математические функции
- •10.2. Функции проверки типов
- •10.3. Функции преобразования форматов
- •10.4. Функции обработки строк
- •10.5. Функции времени и даты
- •11. Обработка ошибок
- •11.1. Предотвращение ошибок программными средствами
- •11.2. Обработка ошибок, инструкция On Error
- •12. Разработка пользовательского интерфейса
- •12.1. Форма (UserForm)
- •12.1.1. Вставка формы
- •12.1.2. Основные свойства и методы формы
- •12.1.3. События формы
- •12.2. Элементы управления формы vba
- •12.2.1. Некоторые общие свойства элементов управления
- •12.2.2. Соглашения об именах
- •12.2.3. Некоторые общие методы элементов управления
- •12.2.4. Общие события элементов управления
- •12.3. Кнопка (СоmmandButton)
- •12.4. Поле (TextBox)
- •12.5. Надпись (Label)
- •Начальные условия
- •Выполнение задания:
- •12.6. Список (ListBox)
- •12.6.1. Основные свойства элемента управления ListBox
- •12.6.2. Методы ListBox
- •12.6.3. Заполнение списка
- •12.6.4. Пример создания списка
- •12.6.5. Определение выбранных элементов списка
- •12.7. Поле со списком (ComboBox)
- •12.8. Флажок (CheckBox)
- •12.9. Выключатель (ToggleButton)
- •12.10. Переключатель (OptionButton)
- •12.11. Полоса прокрутки (ScrollBar) и счетчик (SpinButton)
- •12.12. Создание нестандартных меню и панелей инструментов
- •12.12.1. Объект CommandBar и семейство CommandBars
- •12.12.2. Методы объекта CommandBar
- •12.12.3. Свойства объекта CommandBar
- •12.12.4. Семейство CommandBarControls и объект CommandBarControl
- •12.12.5. Пример создания/удаления панели инструментов
- •12.12.5.1.Создание панели инструментов
- •12.12.5.2. Удаление панели инструментов
- •12.12.6. Пример создания/удаления меню
- •12.12.6.1. Создание меню
- •12.12.6.2. Удаление меню
- •13. Обработка событий объектов Workbook и Worksheet
- •13.1. События объекта Workbook
- •13.1.1. Событие Open
- •13.1.2. Событие BeforeClose
- •13.1.3. Событие SheetActivate
- •13.2. События объекта Worksheet
- •13.2.1. Событие Activate
- •13.2.2. Событие Deactivate
- •13.2.3. Событие SelectionChange
- •Библиография
12.6.2. Методы ListBox
Метод |
Описание |
Clear |
Удаляет все элементы списка |
RemoveItem |
Удаляет элемент с указанным номером из списка. Синтаксис: RemoveItem(Index) |
AddItem |
Добавляет элемент в список. Синтаксис: AddItem([Item [, varIndex]]) Item – элемент (строковое выражение), добавляемый в список varIndex – номер добавляемого элемента |
12.6.3. Заполнение списка
Заполнить список можно одним из следующих способов:
поэлементно (список состоит из одной колонки):
With lstМесяцы
.AddItem "Январь"
.AddItem "Февраль"
.AddItem "Март"
End With
массивом (список состоит из одной колонки):
lstМесяцы.List = Array ("Январь", _
"Февраль",…,"Декабрь")
или
Dim Месяцы(12) As String
Месяцы(1) = "Январь"
Месяцы(2) = "Февраль"
…
Месяцы(12) = "Декабрь"
lstМесяцы.List = Месяцы
поэлементно (список состоит из нескольких колонок, например, двух):
With lstСтудент
.СolumnCount = 2
.AddItem "Иванов"
.List(0,1) = "Алексей"
.AddItem "Петров"
.List(1,1) = "Борис"
.AddItem "Смирнов"
.List(2,1) = "Борис"
End With
массивом (список состоит из нескольких колонок, например, двух):
ReDim Преподаватели(КолСотрудников, 2)
For i = 3 To КолСотрудников
Преподаватели(КолСотрудников, 1) = _
Cells(НомерСтроки,2).Value
Преподаватели(КолСотрудников, 2) = _
Cells(НомерСтроки,3).Value
Next i
lstСотрудники.List = Преподаватели
12.6.4. Пример создания списка
Предположим, что нам надо создать следующую форму с перечнем сотрудников кафедры:
Требуется написать программу инициализации формы, в которой:
список сотрудников должен быть разбит на 2 колонки (1-я колонка – Ф.И.О, 2-я – должность);
предусмотрена возможность выбора нескольких элементов;
данные, на основе которых формируется этот список, находятся на рабочем листе Кадры в книге C:\St\Институт.xls (рис. 12.14).
Рис. 12.14. Структура базы данных Кадры
Тогда фрагмент кода, который формирует список, запишется так:
' 1. Массив Преподаватели объявляем как _
динамический массив
Dim Преподаватели() As String
Dim ПреподавателиТранс() As String
Dim НомерСтроки As Integer
Dim КолСотрудников As Integer
. . . .
НомерСтроки = 3
КолСотрудников = 0
' 2. Считываем данные в динамический массив:
While Trim(Cells(НомерСтроки,2).Value) <> ""
If Trim(Cells(НомерСтроки, 1).Value) = "АСУ" Then
КолСотрудников = КолСотрудников + 1
ReDim Preserve Преподаватели(2, КолСотрудников)
Преподаватели(1,КолСотрудников) = _
Cells(НомерСтроки,2).Value
Преподаватели(2,КолСотрудников) = _
Cells(НомерСтроки,3).Value
End If
НомерСтроки = НомерСтроки + 1
Wend
' 3. Транспонируем массив Преподаватели:
ReDim ПреподавателиТранс(КолСотрудников, 2)
For i = 1 To КолСотрудников
ПреподавателиТранс (i, 1) = Преподаватели (1, i)
ПреподавателиТранс (i, 2) = Преподаватели (2, i)
Next i
' 4. Заполняем список, состоящий из двух колонок:
With lstCотрудник
.СolumnCount = 2
.List = ПреподавателиТранс
End With
ЗАМЕЧАНИЯ:
1. Если Вы формируете список из массива (как в приведенном примере), то количество его элементов задает первый индекс массива. Соответственно в первую колонку списка будут считываться данные из 1-й «колонки» массива (во вторую – из второй и т.д.). Поэтому нам пришлось транспонировать массив Преподаватели в массив ПреподавателиТранс. Можно обойтись одним массивом и тогда этот же фрагмент кода запишется так:
Dim Преподаватели() As String
Dim НомерСтроки As Integer
Dim КолСотрудников As Integer
. . . .
НомерСтроки = 3
КолСотрудников = 0
'1. Определяем количество записей в конечном _
массиве:
While Trim(Cells(НомерСтроки,2).Value) <> ""
If Trim(Cells(НомерСтроки, 1).Value) = _
"АСУ" Then КолСотрудников = _
КолСотрудников + 1
НомерСтроки = НомерСтроки + 1
Wend
'2. Выделяем память для динамического массива и _
считываем в него данные:
ReDim Преподаватели(КолСотрудников, 2)
For i = 3 To НомерСтроки - 1
If Trim(Cells(НомерСтроки, 1).Value) = "АСУ" Then
КолСотрудников = КолСотрудников + 1
Преподаватели(КолСотрудников,1) = _
Cells(НомерСтроки,2).Value
Преподаватели(КолСотрудников,2) = _
Cells(НомерСтроки,3). Value
End If
Next i
'3. Заполняем список, состоящий из двух колонок:
With lstCотрудник
.СolumnCount = 2
.List = Преподаватели
End With
2. Чтобы облегчить работу пользователя, всегда сортируйте элементы списка1 или выстраивайте их так, как это будет ему удобно! В нашем примере первым элементом списка можно было бы прописать сотрудника с должностью Зав.кафедрой.
