Телефон: +7 (495) 649-0526

Циклы в VBA

Картинка к странице

Следующая статья:

Содержание

Повторение действий: циклы

Процесс выполнения всех операторов, заключенных в структуру цикла, один раз называется итерацией ( iteration ) цикла. Некоторые структуры цикла организуются так, что они всегда выполняются заданное количество раз. Структуры цикла, всегда выполняющиеся заданное количество раз, называются циклами с фиксированным числом итераций ( fixed iteration ). Другие типы структур цикла повторяются переменное количество раз в зависимости от некоторого набора условий. Поскольку количество раз повторений этих гибких структур цикла является неопределенным, такие циклы называются неопределенными циклами ( indefinite loops ).

Существуют два основных способа создания неопределенного цикла. Можно построить цикл так, что VBA будет тестировать некоторое условие (детерминант цикла) перед выполнением цикла. Если условие для повторения цикла не равно True, VBA пропускает все операторы в цикле. Можно также построить цикл таким образом, что VBA будет тестировать условие детерминанта цикла после выполнения операторов в цикле.

Самой простой структурой цикла является фиксированный цикл. VBA предоставляет две различные структуры фиксированного цикла: For… Next и For Each … Next. Обе структуры фиксированного цикла называются циклами For, потому что они всегда выполняются для ( for ) заданного количества раз.

Использование цикла For … Next

Цикл For…Next используется, когда необходимо повторить действие или ряд действий заданное количество раз, известное до начала выполнения цикла.

Цикл For…Next имеет следующий синтаксис:

For а=Start To End [Step StepSize ]

операторы

Next [а],

где а – любая численная переменная VBA, обычно переменная типа Integer или Long;

Start - любое численное выражение, определяет начальное значение для переменной а ;

End - это также численное выражение, определяет конечное значение для переменной а.

По умолчанию VBA увеличивает переменную а на 1 каждый раз при выполнении операторов в цикле (считает количество циклов). Можно задавать другое значение ( StepSize ), на которое будет изменяться а, включая необязательное ключевое слово Step. При включении ключевого слова Step необходимо задавать значение для изменения переменной а.

Операторы представляют один, несколько или ни одного оператора VBA. Эти операторы составляют тело цикла For; VBA выполняет каждый из этих операторов каждый раз при выполнении цикла.

Ключевое слово Next сообщает VBA о том, что достигнут конец цикла; необязательная переменная а после ключевого слова next должна быть той же самой переменной а, которая была задана после ключевого слова For в начале структуры цикла.

Включайте необязательную переменную а после ключевого слова next для улучшения читабельности программного кода (особенно при использовании вложенных циклов for next) и для повышения скорости выполнения кода (иначе vba придется потратить время на определение того, какая переменная является правильной, для ее изменения после достижения ключевого слова next).

Цикл For Each … Next

Второй цикл For, который имеется в VBA, – это цикл For Each … Next. В отличие от цикла For…Next, цикл For Each … Next не использует счетчик цикла. Циклы For Each … Next выполняются столько раз, сколько имеется элементов в определенной группе, такой как коллекция объектов или массив. Другими словами, цикл For Each … Next выполняется один раз для каждого элемента в группе.

Цикл For Each … Next имеет следующий синтаксис:

For each а in группа

операторы

Next [а],

где а – это переменная, используемая для итерации по всем элементам в определенной группе;

группа - это объект коллекции или массив. Если группа - это объект коллекции, то а должна быть переменной типа variant, object или заданным объектным типом, таким как range, worksheet, document, paragraph и так далее

Если группа - это массив, то а должна быть переменной типа variant;

операторы - один, несколько или ни одного оператора VBA, составляющих тело цикла.

Видео: «Музыка из звуков винды»

Из звуков винды можно создать довольно интересную музыку

Музыка из звуков винды
Интересное в интернете: нужны модели на выставку рекламное агентство нова

Статья: Циклы в VBA

Раздел: VBA программирование (office)

Сайт: SD Company » Все разделы статей

Последнее изменение: 2010.11.17 в 00:27

Теги: циклы, for, while, vba

Следующая статья:

Введение в VBA
Введение в VBA
Изучение и применение на практике языка программирования Visual Basic for Application (VBA) и особенностей его применения с такими приложениями, как Microsoft Word и Microsoft Excel
Ошибки в HTML
Ошибки в HTML
Что бы улучшать свой сайт, требуется обрабатывать страницы с ошибками, в статье рассматривается каждый тип ошибки
Фишки на HTML
Фишки на HTML
В статье рассматриваются несколько различных фишек при помощи HTML и CSS кодов, примеры прилагаются
Диалекты SQL
Диалекты SQL
Описываются основные различия в написании баз данных (диалекты), их различия, преимущества и недостатки
Типы данных DB2
Типы данных DB2
Основные типы данных используемые в платформе DB2, отличие от классического стандарта
Команды RAR
Команды RAR
Статья для тех, кто часто пользуется архиватором файлов WinRAR, но многое не знает о его функционале
Примеры
Примеры
Приведены примеры обработки данных в базе с помощью Java, а также тип данных Sybase Adaptive Server