- •Электронный учебник
- •Уважаемые студенты! Данный учебник поможет овладеть вам программированием на Visual Basic for Application.
- •Содержание:
- •Разветвляющаяся структура Операции сравнения Теория Варианты задач
- •Знакомство с VBA
- •Типы данных
- •Тип данных
- •Тип данных
- •Переменные
- •Все переменные, созданные таким способом, получают тип Variant. Чтобы запретить неявное объявление переменных,
- •Константы
- •Имеется также большой список предопределенных, или, как говорят, внутренних констант. Характерным для них
- •3.В списке Project/Library выберите библиотеку, со списком констант, например
- •VBA содержитМатематическиестандартный набор математическихфункции функций, перечень которых можно найти в окне Object
- •Функции преобразования
- •Функции взаимодействия с пользователем
- •Пользовательские функции
- •В Excel в любые две ячейки вносим необходимые нам значения x и y.
- •Нажимаем кнопку ОК и в ячейке С1 получаем результат. Пользоваться функциями очень удобно.
- •Арифметические операции
- •Теория
- •После запуска программы на выполнение перед вами выскочит окно, в котором будет написано
- •Метод Cells несколько отличается от метода Range. Необходимая ячейка определяется по номеру своей
- •Пример 1. Составьте программу на языке VBA для вычисления площади прямоугольного треугольника по
- •Пример 2. Составьте программу на языке VBA для вычисления площади круга по радиусу,
- •Варианты задач
- •4. Вычислить площадь куба по его стороне.
- •8. Вычислить процентное отношение двух чисел (сколько процентов составляет величина первого от величины
- •12. Вычислить объем шара по заданному радиусу.
- •Операции сравнения
- •Теория
- •Часто решение определенной задачи требует соблюдение нескольких условий сразу, либо одного из нескольких.
- •Теперь поговорим немного о синтаксисе разветвляющейся структуры. Существуют так называемые одно- и многовариантные
- •Пример 1. Составьте программу на языке VBA для задачи: Определить, попадает ли точка
- •Пример 2. Составьте программу на языке VBA для задачи: Решить квадратное уравнение, заданное
- •Варианты задач
- •3. Ввести число Х и проверить, что больше: sin(X), cos(X) или tg(X). Х
- •4.Определить, принадлежит ли точка (x,y):
- •5. Определить, какая из двух точек (a,b) и (c,d) больше удалена от центра
- •9. Найти сумму n первых членов геометрической прогрессии с первым членом А и
- •11. Ввести 3 стороны прямоугольного треугольника A,B,C. Определить, какая из них является гипотенузой.
- •12. Определить, может ли существовать треугольник со сторонами A,B,C.
- •Теория
- •Вместо числа 100 мы могли поставить какую-либо переменную, единственное условие – эта переменная
- •Циклы Do While – Loop. Цикл с предусловием или неопределенный цикл. Очень похоже
- •Цикл Do Until работает как цикл с предусловием. Отличие в алгоритме работы цикла
- •Пример 1. Составьте программу на языке VBA для задачи: Найти сумму n членов
- •Варианты задач
- •5. Найти сумму n членов ряда
- •8. Найти сумму цифр целого числа n. n должно быть больше 0 (проверить).
- •14. Имеется два сосуда. В первом находится С1 литров воды, а во втором
- •Теория
- •Здесь определяется массив, размерность которого 6 элементов (5,6,7,8,9,10).
- •Пример 1. Составьте программу на языке VBA для задачи: Ввести вещественный массив длины
- •Пример 2. Составьте программу на языке VBA для задачи: Ввести целый массив длины
- •Варианты задач
- •Создание пользовательской
- •В качестве примера разберем решение квадратного уравнения через его коэффициенты. Нам необходимо пять
- •Private Sub CommandButton1_Click()
Арифметические операции
Арифметические операции позволяют выполнить все стандартные арифметические действия:
+ |
– операция сложения, например, A1+A2 складывает A1 и A2; |
– |
– операция вычитания, например, A1–A2 вычитает A2 из A1; |
– |
– унарный минус, например, –A1 изменяет знак у A1; |
* |
– операция умножения, например, A1*A2 умножает A1 и A2; |
/ |
– операция деления, например, A1/A2 делит A1 на A2; |
\ |
– операция целочисленного деления, например, A1\ A2 делит |
A1 на A2, отбрасывая дробную часть; |
|
Mod |
– операция деления по модулю, например, A1 Mod A2 делит A1 |
на A2, возвращая остаток от деления. Остаток – целое число; |
|
^ |
– операция возведения в степень, например, A1^ A2 возводит |
A1 в степень A2.
Теория
Вы уже готовы к программированию. В самой первой строке окна модуля пишем Sub <название программы> ().
В каждой программе используются переменные. Каждая переменная различного типа описывается отдельно. Переменные одного и того же типа можно описывать через запятую. Например, Dim a as integer (это значит «переменная а типа integer»). Если переменную х вы хотите описать типом Single, то придется начать со следующей строки. Кстати VBA очень ревниво следит за правильной орфографией и пунктуацией строк вашей программы, поэтому будь внимательны и осторожны, в противном случае будете получать множество сообщений об ошибках еще до запуска.
Далее. Организация ввода и вывода. Чтобы занести ваши числа в программу надо присвоить эти числа вашим переменным. Осуществляется через команду ввода inputbox(“сообщение”). Например:
F=inputbox(“введите значение F”)
После запуска программы на выполнение перед вами выскочит окно, в котором будет написано «введите значение F». В окошко вы вводите необходимое вам число и нажимаете ОК. После чего переменной F будет присвоено численное значение.
Для вывода необходимо набрать MsgBox. Далее не надо даже скобок как в операторе ввода, просто ваша переменная. Если за переменной вы хотите вывести какое-нибудь сообщение - MsgBox m & “сообщение”.
Не стоит забывать, что VBA тесно связан с MS Excel. Ввод и вывод можно осуществлять непосредственно с листов вашей рабочей книги. Рассмотрим на примерах метод Range:
X=Worksheets(“Лист1”).Range(“В1”).Value – присваиваем переменной Х значение ячейки В1 листа Лист1.
Worksheets(“Лист1”).Range(“В1”).Value=X – выводим в ячейку В1 листа Лист1 значение переменной Х.
Worksheets(“Лист1”).Range(“C1”,”D6”).Value=2 – выводим в ячейки С1 и D1 листа Лист1 число 2
Worksheets(“Лист1”).Range(“B7:C9”).Value=2 – выводим в диапазон ячеек “B7:C9” листа Лист1 число 3.
Метод Cells несколько отличается от метода Range. Необходимая ячейка определяется по номеру своей строки и столбца, т. е. вместо букв А, В, С и т. д. используются цифры 1, 2, 3 и т. д.
X=Worksheets(1).Cells(3,2).Value – переменной Х присваивается значение ячейки из третьей строки и второго столбца (В3) первого листа.
Переменная получает свое значение применением к ней оператора присваивания, который обозначается символом равно "=". В общем случае синтаксис следующий
<переменная> = <выражение>.
Действие оператора присваивания состоит в том, что переменная слева от знака равенства получает значение выражения справа. Оператор присваивания требует согласования типа выражения с типом переменной, записанной слева от него. Например, для получения данных от пользователя используются функция ввода данных InputBox, которая возвращает строку ввода. Если требуется числовой ввод от пользователя, то применяют функцию преобразования, например, CSng.
В линейной структуре все операторы исполняются друг за другом, строка за строкой. Никогда не уклоняясь от последовательности. Рассмотрим пример решения задачи.
Пример 1. Составьте программу на языке VBA для вычисления площади прямоугольного треугольника по двум катетам.
Входные (вводные) данные, как понятно из условия задачи, это длины двух катетов. Формула для вычисления площади прямоугольного треугольника (0,5*a*b), где a и b – катеты треугольника. Наша программа будет иметь следующий вид:
1.Название программы
2.Описание переменных a, b, s (где s – это площадь треугольника)
3.Ввод переменных a и b
4.Нахождение s по формуле s=0.5*a*b
5.Вывод “площадь треугольника равна” & s
6.Конец программы
В VBA эта запись будет выглядеть так: Sub z1_v3()
Dim a, b, s As Single
a = InputBox("введите а") b = InputBox("введите b") s = 0.5 * a * b
MsgBox " площадь треугольника равна " & s End Sub
Пример 2. Составьте программу на языке VBA для вычисления площади круга по радиусу, если радиус задан вектором.
Логическая запись: 1. Название программы
2.Описание переменных x, y, s (где s – это площадь круга; x, y – координаты радиус-вектора)
3.Ввод переменных x и y
4.Нахождение s по формуле s= 3.14*(x^2+y^2) (значок ^ - обозначает возведение в степень)
5.Вывод “площадь круга равна” & s 6.Конец программы
Запись на VBA: Sub zad1_v4()
Dim x, y, s As Double
x = InputBox("введите x") y = InputBox("введите y") s = 3,14 * (x ^ 2 + y ^ 2)
MsgBox s & " –площадь круга" End Sub.
Варианты задач
Составьте блок-схему и программу на VBA для задач:
1. Вычислить значения функции
f(x,y,z) = (x^2 – y^2)/(1 + z + x^2) Примечание. ^ означает степень.
Исходные данные Результат
x=1 y=2 z=3.9 f(x,y,z) = -0.50847457627
2. Вычислить значения функции
|
f(x,y,z) = (x + y + z)/(x^2 + y^2 + z^2) |
Примечание. ^ означает степень. |
|
Исходные данные |
Результат |
x=5 y=3.3 z=2.6 |
f(x,y,z) = 0.25556858148 |
3. Вычислить значения функции |
|
|
f(x,y) = x/(1 + y) + y/(1 + x) + 1/(x + y) |
Исходные данные |
Результат |
x=4 y=3.2 |
f(x,y) = 1.7312698413 |
4. Вычислить площадь куба по его стороне.
Исходные данные |
Результат |
a = 3 |
S = 54 |
5. Вычислить значения функции
f(x,y,z) = (x + y + z)/(xyz)
Исходные данные |
|
Результат |
x=7.1 y=1 z=2 |
f(x,y,z) = 0.71126760563 |
|
6. Вычислить вектор по двум его концам. |
||
Исходные данные |
|
Результат |
x1=2 y1=4 x2=3 y2=-1 |
Вектор равен (1,-5) |
7. Вычислить значения функции
f(a,b,c,x) = ax^2 + bx + c Примечание. ^ означает степень.
Исходные данные |
Результат |
a=2.4 b=0.7 c=9.1 x=3 |
f(a,b,c,x) = 32.8 |
8. Вычислить процентное отношение двух чисел (сколько процентов составляет величина первого от величины второго).
Исходные данные |
Результат |
Первое число 5.7 |
|
Второе число 8.7 |
65.517241379% |
9. Вычислить значения функции
f(x,y,z) = x/y/z + z/y/x + y/x/z
Исходные данные |
Результат |
x=5.9 y=2.1 z=2.8 |
f(x,y,z) = 1.3565087052 |
10. Вычислить дискриминант квадратного уравнения. Исходные данные Результат
a=5.9 b=8.9 c=0.7 Дискриминант D = 62.69
11. Вычислить значения функции
|
f(x,y) = (x + y)(x^2 + y^2)(x^3 + y^3) |
Примечание. ^ означает степень. |
|
Исходные данные |
Результат |
x=1.9 y= 5.4 |
f(x,y) = 39309.512383 |
12. Вычислить объем шара по заданному радиусу.
Исходные данные |
Результат |
r = 5.78 |
Объем шара V = 808.85770076 |
13. Вычислить объем цилиндра по заданным радиусу и высоте. Исходные данные Результат
r=5.1 h=1.9 Объем цилиндра V = 155.25436735
14. Вычислить значения функции
f(x,y,z) = (xyz)/(x + y^2 + z^3) Примечание. ^ означает степень.
Исходные данные |
Результат |
x=1.1 y=2 z=4.6 |
f(x,y,z) = 0.09879339295 |
15. Вычислить длину главной диагонали параллелепипеда.
Исходные данные |
Результат |
a=4 b=3 c=6 |
Длина диагонали L = 7.8102496759 |