Циклы VBA (ч.2). Циклы тестирующие условия до и после выполнения тела цикла
Существуют два основных способа создания неопределенного цикла. Можно построить цикл так, что VBA будет тестировать некоторое условие (детерминант цикла) либо перед выполнением цикла, либо - после выполнения цикла.
Цикл Do .. While
Конструкция цикла, тестирующая свое условие детерминанта до выполнения цикла.
Синтаксис:
Do While Condition
Statements
Loop
Condition - логическое выражение для детерминанта цикла
Statements - один, ни одного или несколько операторов, которые составляют тело цикла
Loop - ключевое слово, указывает на окончание тела цикла и обозначает место, из которого VBA возвращается в начало цикла для проверки условия
VBA выполняет цикл пока логическое выражение, представленное с помощью Condition, равно True.
При выполнении цикла Do While сначала тестируется логическое выражение (Condition); если оно равно True - выполняется тело цикла. При достижении ключевого слова Loop управление опять передается в начало цикла и снова проверяется логическое выражение. Так происходит до тех пор, пока логическое выражение не станет False. Когда логическое выражение становится False - управление передается оператору, следующему за ключевым словом Loop.
Обратите внимание! Если логическое выражение равно False при первом выполнении цикла Do While, то управление сразу передается оператору, следующему за Loop, а операторы, находящиеся в теле цикла соответственно пропускаются. Другими словами говоря, цикл Do While позволяет ни разу не выполнять операторы внутри него.
В нижеприведенном листинге представлен элементарный цикл Do While, подсчитывающий сумму цифр от 1 до 10:
Цикл Do .. Until
Еще один цикл, тестирующий условие детерминанта до выполнения цикла.
Синтаксис:
Do Until Condition
Statements
Loop
Condition - логическое выражение для детерминанта цикла
Statements - один, ни одного или несколько операторов, которые составляют тело цикла
Loop - ключевое слово, указывает на окончание тела цикла и обозначает место, из которого VBA возвращается в начало цикла для проверки условия
VBA выполняет цикл пока логическое выражение, представленное с помощью Condition, равно False.
В остальном цикл Do Until полностью аналогичен циклу Do While.
Листинг, использующий цикл Do Until для подсчета цифр от 1 до 10, будет выглядеть так:
Для тестирования условий после выполнения тела цикла надо поместить логическое выражение в конец блока операторов, составляющих тело цикла, после ключевого слова Loop, которое сообщает о конце цикла.
Цикл Do .. Loop While
Конструкция цикла, тестирующая свое условие детерминанта после выполнения цикла.
Синтаксис:
Do
Statements
Loop While Condition
Condition - логическое выражение для детерминанта цикла
Statements - один, ни одного или несколько операторов, которые составляют тело цикла
Loop - ключевое слово, указывает на окончание тела цикла и обозначает место, из которого VBA возвращается в начало цикла после проверки условия
VBA выполняет цикл пока логическое выражение, представленное с помощью Condition, равно True.
При выполнении цикла Do Loop While сначала выполняются операторы тела цикла, затем по достижении ключевого слова Loop тестируется логическое выражение (Condition); если оно равно True - управление передается в начало тела цикла и цикл повторяется снова. Так происходит до тех пор, пока логическое выражение не станет False. Когда логическое выражение становится False - управление передается оператору, следующему за строкой Loop While...
Обратите внимание! Даже если при первом выполнении цикла Do Loop While логическое выражение равно False тело цикла всё равно будет выполнено. Другими словами говоря, независимо от значения логического выражения, представленного с помощью Condition, этот цикл всегда выполняется, по крайней мере, один раз.
Листинг, использующий цикл Do Loop While для подсчета цифр от 1 до 10, будет выглядеть так:
Цикл Do .. Loop Until
Еще один цикл, тестирующий условие детерминанта после выполнения цикла.
Синтаксис:
Do
Statements
Loop Until Condition
Condition - логическое выражение для детерминанта цикла
Statements - один, ни одного или несколько операторов, которые составляют тело цикла
Loop - ключевое слово, указывает на окончание тела цикла и обозначает место, из которого VBA возвращается в начало цикла после проверки условия
VBA выполняет цикл пока логическое выражение, представленное с помощью Condition, равно False.
В остальном цикл Do Loop Until полностью аналогичен циклу Do Loop While.
Листинг, использующий цикл Do Loop Until для подсчета цифр от 1 до 10, будет выглядеть так:
Следует сказать, что представленные выше примеры даны чисто в познавательных целях, чтобы можно было понять саму суть организации неопределенных циклов с проверкой условий до и после выполнения тела цикла. Сама же гибкость неопределенных циклов здесь явно не просматривается.