• Vba for next переход к следующему значению. Операторы цикла в VBA. Лабораторные работы по основам программирования

    В этом уроке будет рассмотрена работа с циклом For в VBA. Пример работы с циклом For, так же будет продемонстрирован пример создания формул в Excel с помощью макросов.

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

    Цикл For имеет следующий синтаксис:
    For счетчик = начало цикла To конец цикла [Step шаг ]
    группа операторов, команд и т.д.
    Exit For
    Next счетчик

    • "счетчик" - переменная, которая изменяется на указанный "шаг". Если шаг не указан, то по умолчанию берется единица.
    • "начало цикла" , "конец цикла" - числа или переменные указывающие нижний предел счетчика и верхний. Остановка цикла происходит тогда, когда "счетчик" > "конец цикла" (или, если цикл обратный, т.е. с шагом -1, то "счетчик" < "конец цикла").
    • Exit For – команда принудительной остановки цикла. Применяется в тех случаях, когда произошло некоторое событие, после которого необходимо остановить выполнение команд в цикле, или для предотвращения возникновения ошибки.

    Рассмотрим пару примеров использования цикла For . В дальнейшем, с этим циклом будем встречаться довольно часто.

    Пример 1
    Даны два столбца С и Е заполненные числами:

    Необходимо сложить числа в столбце С с числами столбца Е следующим образом:
    С2+Е21, С3+E20, ..., C21+E2. Результат вывести в столбец D в виде формулы т.е. содержание ячейки результата должно быть "=С2+Е21".

    Код макроса выглядит следующим образом (куда прописывать код читаем ):

    Sub Цикл_For()
    "константа указывающая предел цикла т.е. до какого значения циклу бежать
    Const n = 21
    For i = 2 To n
    " создаем строку формулу и сохраняем ее в ячейку
    Cells(i, 4) = "=C" & CStr (i) & "+E" & CStr ((n - i) + 2)
    " продолжение когда выполняющегося в цикле
    Next i
    " остальной код программы
    End Sub

    Разбираем написанный код:

    • Const n = 21 - описание константы n со значением 21, т.е. число строк по которому необходимо пробежаться циклу For ;
    • For i = 2 To n - i счетчик который будет изменяться на 1 с каждым проходом цикла. Счетчик начинается с 2 и заканчивается когда i>n;
    • Cells(i, 4) - ячейка выделенного листа, i номер строки, 4 -номер столбца в который выводится результат. Обратите внимание, наш счетчик i указывает номер строки листа Excel;
    • Next i - оператор закрытия цикла и перевода указателя к For. Все что находится между For и Next выполняется в цикле;
    • CStr - функция преобразующая число в текст.

    Ячейке мы присваиваем формулу созданную следующим образом "=C" & CStr (i) & "+E" & CStr ((n - i) + 2). Знак & - "склеивание" символов, строк. В результате у нас получится формула "=Сn+E((n - i) + 2)" где n = 21, i - счетчик.
    Страшно? Это только кажется:)

    Все. После выполнения макроса мы получим следующий столбец (выделен), а в каждой ячейке формула:

    Пример 2
    Теперь рассмотрим цикл с указанным шагом. После расчета прошлого макроса мы получили три столбца, теперь нам необходимо из столбца E вычесть D, в столбец F вывести формулы вычитания. Код макроса следующий:

    Sub Цикл_For_с_шагом()
    Const n = 21
    For i = n To 2 Step -1
    Cells(i, 6) = "=E" & CStr (i) & "-D" & CStr (i)
    Next i
    End Sub

    В данном случае все тоже самое, только цикл теперь "бежит" не от 2, а от 21 до 2 с шагом (Step) -1.
    Результат выполнения получим следующий:

    Цикл For , в VBA, является не единственным циклом. В дальнейшем будут рассмотрены еще пара вариантов циклов, без которых не обойтись при написании макрокоманд в Excel.

    Какие либо действия процедуры повторяющиеся заданное количество раз или пока выполняется или не выполняется некоторое условие называют циклом .

    Процесс выполнения все операторов, заключенных в структуру цикла, один раз называется итерацией цикла .

    Структуры цикла, всегда выполняющиеся заданное количество раз, называются циклами с фиксированным числом итераций . Другие типы структур цикла повторяются переменное количество раз в зависимости от некоторого набора условий. Такие циклы называются неопределенными циклами .

    Блок операторов, находящийся между началом и концом цикла называется "тело цикла" .

    Самой простой структурой цикла является фиксированный цикл .

    Цикл For..Next

    Синтаксис

    For counter = Start To End
    Statements
    Next [counter ]

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


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

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


    Ниже представлен листинг простейшего цикла For..Next , который считает сумму цифр от 1 до 10:



    А теперь два варианта цикла For..Next с использованием шага цикла отличного от единицы:



    Обратите внимание! При уменьшении счетчика цикла For..Next цикл выполняется, пока переменная счетчика больше или равна конечному значению, а когда счетчик цикла увеличивается, цикл выполняется, пока переменная счетчика меньше или равна конечному значению.

    Цикл For Each..Next

    Цикл For Each..Next не использует счетчик цилка. Циклы For Each..Next выполняются столько раз, сколько имеется элементов в определенной группе, такой как коллекция объектов или массив (которые будут рассматриваться позже). Проще говоря, цикл For Each..Next выполняется один раз для каждого элемента в группе.

    Синтаксис

    For Each Element In Group
    Statements
    Next [Element ]

    Element - переменная, используемая для итерации по всем элементам в определенной группе
    Group - это объект коллекции или массив
    Statements - один, несколько или ни одного оператора VBA (тело цикла).

    Алгоритм цикла For….Next приведен на рис. 5.28.

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

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

    End – численное выражение, определяющее конечное значение для переменной Counter .

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

    Ключевое слово Next

    Counter=counter+StepSise

    Рис.9.28. Алгоритм цикла For….Next

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

    Синтаксис :

    For counter = Start To End

    При выполнении цикла For Next VBA поступает следующим образом:

    Присваивает значение, представленное Star , переменной С ounter .

    Выполняет все операторы, представленные с помощью Statements , пока не достигнет ключевого слова Next . Ключевое слово Next показывает VBA на то, что достигнут конец тела цикла.

    Изменяет переменную С ounter на величину StepSize (если включается необязательное слово Step) Если Step не определено, то VBA увеличивает переменную counter на 1.

    Возвращается к началу цикла и сравнивает текущее значение переменной С ounter со значением, представленным End. Если значение С ounter меньше значения End , VBA продолжает выполнение с первого оператора после ключевого слова Next .

    9.2.4. Ввод-вывод одномерных и двухмерных массивов

    Массив (array ) – это коллекция переменных, которые имеют общее имя и базовый тип. Массив является удобным способом хранения нескольких связанных элементов данных в едином контейнере для большего удобства и эффективности программирования. Все элементы данных, сохраняемых в массиве, должны иметь один и тот же тип.

    Массив позволяет сохранять и манипулировать многими элементами данных посредством единственной переменной. Кроме уменьшения общего числа различных имен переменных, которые необходимо отслеживать, другим основным преимуществом использования массивов является то, что можно использовать циклы для легкой обработки различных элементов массивов. Объединяя массивы и структуры цикла (обычно For….Next) можно написать небольшое число операторов, которые обрабатывают большой объем данных. Выполнение тех же задач с использованием отдельных переменных может потребовать написания сотен операторов.

    Размерность массива

    В языках программирования обычно используются одномерные и многомерные массивы, одни из которых описывают относительно простые, а другие более сложные объекты.

    Одномерные массивы

    Пример одномерного массива приведен в таблице № 9.9.

    Таблица № 9.9

    В программировании обычно используется нумерация с нулевой базой.

    Для доступа к данным, хранящимся в определенном элементе массива, следует указывать имя массива с последующим числом, называемым индексом элемента. Индекс заключают в круглые скобки. Например, если массив в таблице № 1.1 имеет имя DoubleArray, то следующий оператор присваивает число 45 переменной DoubleAny.

    DoubleAny = DoubleArray (3)

    В этом операторе число 3 является индексом массива. Поскольку нумерация элементов начинается с нуля, элемент, на который ссылается оператор, является, фактически, четвертым элементом массива DoubleArray.

    При выполнении оператора DoubleArray, VBA выбирает значение 45 и сохраняет это значение в переменной DoubleArray.

    Этот же оператор можно использовать при сохранении данных в массиве:

    DoubleArray (5)=12.

    При выполнении этого оператора VBA помещает значение 12 в указанных элемент массива, заменяя предыдущее содержимое этого элемента.

    Одномерные массивы обычно используются для представления различных списков данных.

    Многомерные массивы

    Когда необходимо представить таблицы данных с организацией данных в формате строк и столбцов, для этого используют многомерные массивы.

    В двумерном массиве адрес каждой ячейки состоит из двух чисел: номер строки (первый индекс) и номер столбца (второй индекс). В VBA можно создавать массивы до 60 измерений.

    Если в массиве число элементов не меняется, то такой массив называется статическим.

    Статические и динамические массивы

    Если при выполнении VBA-программы можно изменять число элементов в массиве, то такие массивы называются динамическими. Для изменения размера динамического массива используется оператор ReDim.

    VBA сохраняет зарезервированной область памяти для всех элементов в массиве, пока существует переменная типа массива. Подобные массивы называются статическими (static), потому что число элементов в массиве не меняется.

    Оператор Option Base

    Обычно в VBA используются массивы с нулевой базой. Оператор Option Base позволяет задавать 0 или 1 как начальное число по умолчанию для индексов массива. Если оператор Option Base не используется, VBA начинает нумерацию индексов с 0 (по умолчанию). Необходимо помещать оператор Option Base в область объявлений модуля перед объявлением любых переменных, констант или процедур. Нельзя помещать оператор Option Base внутри процедуры. Можно иметь только один оператор Option Base в модуле.

    Синтаксис:

    Option Base 0|1

    Объявление массивов

    Объявление массива с помощью оператора Dim имеет следующий синтаксис.

    Синтаксис:

    Dim VarName ()

    Dim VarName ( upper, upper]….) [ As type ],

    VarName – любое имя для массива, удовлетворяющее VBA-правилам для имен идентификаторам.

    Subscripts – измерение массива.

    As Type – тип данных.

    Lower – нижняя граница значения индекса.

    Upper – верхняя граница значения индекса.

    Type – тип данных

    Если опустить тип, все элементы массива будут иметь тип Variant. VBA инициализирует элементы числовых массивов нулями и элементы строковых массивов пустыми строками.

    Dim str_array (1 To 100) As String

    Dim variant_array ()

    Dim str_Multiplication (0 To 15, 0 To 15) As String

    Использование массивов

    Для доступа к элементу массива необходимо указать имя массива, за которым следует значение индекса, заключенное в круглые скобки.

    Обращение к элементу массива имеет следующий синтаксис.

    Синтаксис.

    arrayName (validIndex1, ….)

    validIndex – имя массива.

    validIndex1 – допустимое значение индекса для первого измерения массива.

    validIndex2 – допустимое значение индекса для второго измерения массива.

    Необходимо предоставлять значение индекса для каждого измерения массива при каждом обращении к какому-либо элементу массива.

    Ввод-вывод одномерных массивов

    При вводе одномерного массива необходимо последовательно вводить 1-й, 2-й и т.д. элементы массива, аналогично поступают при выводе. Для ввода или вывода массива необходимо организовать цикл. Наиболее удобно использовать для ввода и вывода одномерного массива алгоритм с использованием безусловного цикла.

    Алгоритм ввода вывода одномерного массива приведен на рис.5.29.

    Расшифровка процедуры приведена ниже.

    Sub Massiv () – название процедуры.

    Dim Mas (5) As Integer - объявили одномерный массив с 5-ю элементами, тип чисел – целые.

    Dim s As String – объявили рабочую переменную для завершающего вывода данных из массива в диалогом окне. As String – тип данных в переменной для хранения.

    For i = 1 To 5 – процедура в первом цикле For….Next, принимает целые числа от 1 до 5 и заносит их в массив.

    Mas (i) = InputBox (i) – ввод целого числа для i-го элемента.

    Next – переход ко второму циклу (элементы массива заносятся в строку и выводятся на экран в диалоговом окне с помощью оператора MsgBox).

    For i = 1 To 5 – элементы в строке с 1 по 5.

    s = s & Mas(i) & “ ;” - формирование строки из элементов массива. Массив выводится в одну строку. Элементы массива разделяются символом “ ;”.

    MsgBox s – вывод ранее введенного массива.

    Рис.5.27. Алгоритм ввода-вывода одномерного

    Рис. 9.29. Алгоритм и процедура ввода-вывода одномерного массива

    Ввод-вывод двухмерного массива

    Алгоритм и процедура ввода и вывода двухмерного массива представлен на рис.5.30.

    Описание данной процедуры:

    Sub Massiv () – название процедуры

    Объявление переменных, которые используются в данной процедуре:

    Dim Mas (5, 5) As Integer - объявили двухмерный массив с 5 столбцами и пятью строками, тип чисел – целые.

    Dim s As String – объявили рабочую переменную для завершающего вывода данных из массива в диалогом окне. As String – тип данных в переменной для хранения

    Next i – окончание операции присвоения переменных

    Ввод элементов массива в память компьютера:

    For i = 1 To 5 – ввод осуществляется с первого элемента первой строки, потом со второго и т.д.

    For j = 1 To 5 до конца первой строки, потом с первого элемента второй строки и т.д.

    Mas(i,j) = InputBox(i,j) – оператор ввода элементов массива в память ЭВМ

    Рис. 9.30. Алгоритм и процедура ввода-вывода двухмерного массива

    Алгоритмы упорядочения массива

    В качестве примера приведем алгоритм и процедуру сортировки одномерного массива методом «пузырька»

    Вывод элементов введенного массива из памяти ЭВМ:

    For i = 1 To 5 – вывод осуществляется аналогично вводу

    s = s & Mas (i,j) & “ ; ”

    s = s & Chr (13) – перевод строки (вывод не одной строкой, а несколькими, как в введенном массиве)

    Next i – окончание действия оператора For….Next

    MsgBox s – вывод ранее введенного массива на диалоговое окно

    End Sub – окончание процедуры.

    Инструкция цикла представляет собой указание, из которого ясно, какой набор инструкций (этот набор инструкций называется телом цикла) нужно выполнять многократно и каково правило окончания выполнения цикла.

    7.2.1. Параметрический цикл For… Next

    Этот цикл управляется параметром, который при повторении выполнения тела цикла изменяет с заданным шагом свое значение от заданного начального значения до заданного конечного значения. Такой цикл используют в случае, когда заранее известно, сколько необходимо совершить повторений выполнения тела.

    Синтаксис цикла: For ИПЦ=НЗПЦTo КЗПЦ[Step ШИПЦ] Тело цикла (одна или несколько инструкций) Next [ИПЦ]

    Слова For (для), To (до), Step (шаг), Next (затем) являются зарезервированными.

    Применены обозначения:

    ИПЦ – имя параметра цикла (переменная любого числового типа);

    НЗПЦ – начальное значение параметра цикла (выражение любого числового типа), которое параметр цикла будет иметь при первом выполнении тела цикла;

    КЗПЦ – конечное значение параметра цикла (выражение любого числового типа), с которым сравнивается текущее значение параметра цикла;

    ШИПЦ – шаг изменения параметра цикла (выражение любого числового типа) – необязательная часть инструкции цикла.

    Числовые значенияНЗПЦ и КЗПЦ задают интервал, в котором будет изменяться параметр цикла. Необязательный параметр ШИПЦ задает шаг изменения счетчика цикла на каждом проходе. По умолчанию, если он отсут–ствует, то принимается равным 1. Наконец, после инструкций, составляющих тело цикла, следует команда, обозначающая границу действия цикла. В случае вложенных циклов (в тело цикла входит инструкция цикла) полезно указывать, к какому из них относится команда Next . Это достигается добавлением после слова Next имени параметра цикла.

    Процесс выполнения инструкции For Next для положительного шага иллюстрирует рисунок 7.4.

    Рассмотрим примеры.

    В первом примере запишем инструкции для вычисления суммы всех целых нечетных чисел от 1 до 100.

    Dim I As Integer, Сумма As Integer

    For i = 1 To 100 Step 2

    Сумма = Сумма +i

    В следующем примере будут продемонстрированы две возможности: явно заданный шаг цикла и отсчет в обратном направлении. Последнее достигается заданием отрицательного шага и тем, что начальное значение параметра цикла больше, чем конечное.

    Dim N As Integer

    For N = 100 To 60 Step –10

    Этот код выведет на текущей форме:

    Следующая инструкция заставляет компьютер подавать звуковой сигнал 50 раз. Инструкция For определяет, что параметром цикла является переменная x , ее начальное и конечное значения. Команда Next изменяет счетчик с шагом.

    Dim x As Integer

    Инструкцию For...Next можно завершить досрочно с помощью инструкции Exit For. Выполнение этой инструкции приводит к немедленному выходу из цикла.

    7.2.2. Инструкция цикла Do While...Loop или Do...Loop While

    Здесь While (пока) и Loop (цикл) зарезервированные слова. Циклы типа While предназначены для ситуаций, когда количество повторений тела цикла (итераций) заранее не известно. Вот синтаксис двух разновидностей цикла While :

    Do While УсловиеПовторения Группа инструкций Loop

    Do Группа инструкций Loop While УсловиеПовторения

    Различие между ними заключается в том, что УсловиеПовторения (условие повторения выполнения тела цикла) проверяется в первом случае до выполнения тела цикла (цикл – пока), а во втором случае – после выполнения тела цикла (цикл – до).

    Перейдем к примерам.

    Рассмотрим действие следующего участка программы.

    Счетчик = 0

    Do While Номер > 10

    Номер = Номер - 1

    Счетчик = Счетчик + 1

    MsgBox ("Выполнено " & Счетчик & ­_

    " итераций цикла.")

    При выполнении этого участка программы в окне функции MsgBox будет выведено:

    Выполнено 10 итераций цикла.

    В этой программе условие проверяется до входа в цикл. Если переменной Номер задать значение, равное 9 вместо 20, инструкции внутри цикла выполняться не будут.

    В следующей программе инструкции внутри цикла выполняются только один раз до того, как условие не будет выполнено.

    Счетчик = 0

    Номер = Номер - 1

    Счетчик = Счетчик + 1

    Loop While Номер > 10

    MsgBox ("В цикле выполнено " & Счетчик & _

    " итераций.")

    Инструкцию Do...Loop можно завершить досрочно с помощью инструкции Exit Do .

    Лабораторные работы по основам программирования

    2.1. Табулирование функций, представленных аналитически
    и сходящимся рядом

    Цель работы

    · Закрепление теоретических знаний по основам организации разветвляющихся и циклических структур.

    · Приобретение практических навыков программирования с использованием разветвляющихся и циклических структур в системе Visual Basic.

    В VB существуют три вида операторов цикла:

    · счетный цикл: For…To … Next

    · циклы с предусловиями: Do While...Loop, Do Until...Loop, While…WEnd

    · циклы с постусловиями:Do...Loop While, Do...Loop Until.

    Счетный цикл – позволяет циклически выполнять набор операторов заданное число раз. Его синтаксис следующий:

    For счетчик = начало To конец

    [операторы ]

    [операторы ]

    Next [счетчик ]

    Параметр счетчик – это числовая переменная (целого, вещественного типа или типа Date, Variant, Currency), которая автоматически увеличивается после каждого повтора. Начальное значение счетчика равно параметру начало, а конечное параметру – конец. Если не указан, то шаг считается равным 1, значение шага можно изменять. Оно может быть положительным или отрицательным числом.

    Существуют четыре синтаксические конструкции цикла Do….Loop:

    Операторы между ключевыми словами Do … Loop выполняются заданное количество раз в зависимости от условия. Например, в следующем фрагменте программы при C = 100 условие будет выполняться и произойдет вход в цикл. Внутри цикла происходит обращение к процедуре и уменьшение значения C на 1. Далее вновь проверяется условие (C > 0) и операторы цикла выполняются повторно (всего они выполнятся 100 раз), до C = 0. Когда же условие C >0 становится ложным и цикл прекращается.

    Do While C > 0

    Тот же самый фрагмент программы, выполненный с использованием цикла с предусловием по синтаксису 2:

    В данном случае цикл выполняется, пока условие равно False, в отличие от предыдущего случая, то есть продолжается до выполнения условия C = 0.

    Операторы циклов по синтаксису 3 и 4 очень похожи на первые два за исключением того, что условие не вычисляется до тех пор, пока цикл не выполнится хотя бы один раз.

    В синтаксисах этих циклов можно использовать операторы безусловного выхода из цикла Exit For и Exit Do, позволяющих передать управление оператору, находящемуся за циклом. Например, в следующем фрагменте программы, если начальное значение C окажется >50, то цикл немедленно прекратиться.



    Do Until C <= 0

    MsgBox “Нач. значение больше допустимого”, ”Ошибка ввода”

    Цикл While…Wend использовался в ранних версиях Visual Basic. Его синтаксис следующий:

    While <условие>

    <Операторы>

    В отличии от цикла Do..Loop цикл While ..Wend не имеет второго варианта, в котором проверка условия выполняется в конце цикла. Кроме того, для него нет оператора выхода из цикла, наподобие Exit Do.