48801 (588613), страница 2

Файл №588613 48801 (Решение задач с помощью современых компьютерных технологий) 2 страница48801 (588613) страница 22016-07-29СтудИзба
Просмтор этого файла доступен только зарегистрированным пользователям. Но у нас супер быстрая регистрация: достаточно только электронной почты!

Текст из файла (страница 2)

Функции преобразования типов данных следует использовать вместо функции Val для совместимости с различными национальными настройками при преобразовании из любого типа данных в другой. Например, при использовании функции CCur разделители целой и дробной частей, а также разделители разрядов и параметры денежных единиц правильно распознаются в зависимости от национальной настройки компьютера.

Если дробная часть числа в точности равна 0,5, то функции CInt и CLng всегда округляют число до ближайшего четного числа. Например, 0,5 округляется до 0, а 1,5 до 2.

Чтобы определить, может ли аргумент дата быть преобразована к типу даты или времени, следует использовать функцию IsDate. Функция CDate распознает литералы даты и литералы времени, а также числа, которые попадают в приемлемый диапазон дат. При преобразовании числа в дату переводится целая часть числа. Любая дробная часть числа преобразуется во время суток, отсчитываемое от полуночи.

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

3.3 Вызов процедур и функций

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

  • Sub

  • Function

  • Property

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

[Private] [Public] [Static} Sub имяПроцедуры (аргументы)

операторы

End Sub

Между ключевыми словами Sub и End Sub в процедуре располагаются выполняемые при ее вызове операторы программного кода. Параметр аргументы можно применять для объявления передаваемых в процедуру переменных.

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

Процедуры обработки событий связаны с объектами, размещенными в формах Visual Basic, или с самой формой и выполняются при наступлении события, с которым они связаны.

Процедуры Function в отличие от процедур sub могут возвращать значение в вызывающую процедуру. Синтаксис процедуры Function выглядит следующим образом:

[Private] [Public] [Static} Function имяПроцедуры (аргументы) [As type]

операторы

End Function

Процедуры Function, как и переменные, имеют тип, задаваемый с помощью ключевого слова As. Если тип процедуры не задан, по умолчанию ей присваивается тип Variant. Тип процедуры определяет в свою очередь тип возвращаемого ею значения. Возвращаемое процедурой значение присваивается имени процедуры имяПроцедуры и может быть использовано в выражениях программного кода аналогично стандартным функциям Visual Basic.

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

Call NameProc (аргумент1, аргумент2, ...аргументы)

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

NameProc аргумент1, аргумент2, ...аргументы

При вызове процедуры модуля формы из другого модуля необходимо указывать ссылку на имя модуля формы, содержащего процедуру. Например, для вызова процедуры с именем Nameproc, находящейся в модуле формы Form1, оператор должен выглядеть так:

Call Form1.NameProc (аргумент1, аргумент2, ...аргументМ)

Вызов процедуры Function аналогичен вызову встроенных функций Visual Basic. Кроме этого, процедуру Function можно вызывать так же, как процедуру Sub:

Call Square(Side)

Square Side

В этом случае Visual Basic игнорирует возвращаемое функцией значение.

Переменные, передаваемые процедуре, называют параметрами процедуры. По умолчанию они имеют тип Variant. Visual Basic позволяет задавать тип параметров с помощью ключевого слова As:

Function Square (intA As Integer) As Integer

Передача параметров в процедуру может осуществляться двумя способами: по значению (by value) и по ссылке (by reference). В первом случае в процедуру в качестве переменной передается не сама переменная, а ее копия. Поэтому изменение параметра в процедуре затрагивает не переменную, а ее копию. Для передачи в процедуру параметров по ссылке используется ключевое слово ByVal, например:

Sub NameProc (ByVal strArg As String)

тело процедуры

End Sub

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

Используя ключевое слово Optional, можно задавать необязательные параметры процедуры. При этом необходимо иметь в виду, что если какой-либо из параметров задан как необязательный, то и расположенные после него параметры также должны быть объявлены необязательными:

Sub NameProc (Optional strArg1 As String, Optional strArg2 As String)

тело процедуры

End Sub

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

Sub NameProc (strArg1 As String, Optional strArg2 As String)

тело процедуры

End Sub

3.4 Связь с рабочим листом

3.4.1 Способы адресации к ячейкам листа

Получить доступ к ячейке листа электронной таблицы Excel можно различными способами:

а) прямая ссылка на имя ячейки:

a = Range(“A1”).Value ‘Получить значение из ячейки A1 текущей таблицы

a = Worksheets(“Лист1”).Range(“A1”).Value ‘Получить значение из ячейки

A1 листа с именем “Лист1” в текущей книге (файле *.xls)

a = Worksheets(1).Range(“A1”).Value

Получить значение из ячейки A1 листа следующего первым по порядку в текущей книге (файле *.xls)

a = Workbooks(“Work.xls”).Worksheets(1).Range(“A1”).Value

Получить значение из ячейки A1 листа следующего первым по порядку в книге “Work.xls

Range (“A1”).Value = a ‘Занести значение из переменной a в ячейку А1

б) прямая ссылка на номер ячейки. Если представить ячейку таблицы, как элемент двухмерной таблицы, то, например, ячейка “A1” будет иметь ссылку “1,1”(строка, столбец).

a = Cells(2,2).Value ‘Получить значение из ячейки В2 текущей таблицы

a = Worksheets(“Лист1”).Cells(2,2).Value

a = Worksheets(1).Cells(2,2).Value

a = Workbooks(“Work.xls”).Worksheets(1).Cells(2,2).Value

Cells(2,2).Value = a ‘Занести значение из переменной а в ячейку В2

в) Косвенная ссылка на имя ячейки. На первом шаге необходимо выделить необходимую ячейку инструкцией Range(“A2”).Select, а далее получить доступ к ячейке с помощью инструкции ActiveCell.FormulaR1C1 (всегда возвращается значение типа текст, поэтому необходимо преобразовывать полученное значение с помощью функций CDbl, CInt, Val и тому подобных):

Range(“A2”).Select ‘Перейти на ячейку А2 текущей таблицы

a = CDbl(ActiveCell.FormulaR1C1) ‘Получить значение из выделенной ячейки и преобразовать его к типу Double

Range(“A2”).Select ‘Перейти на ячейку А2 текущей таблицы

ActiveCell.FormulaR1C1 = a ‘Занести значение переменной а в выделенную ячейку

Для выделения ячейки А1 определенного листа в определенной книге (файле *.xls) необходимо:

  1. активизировать открытую книгу (файл *.xls) инструкцией Windows(“Книга2.xls”).Activate;

  2. активизировать нужный лист книги инструкцией Worksheets(“Лист1”).Activate;

  3. перейти к ячейке: Range(“A1”).Select.

г) косвенная ссылка на ячейку по приращению. Позволяет выделить ячейку (перейти к ячейке) по приращению от текущей (Offset (приращение_по_строке, приращение_по_столбцу)):

ActiveCell.Offset(0,1).Range(“A1”).Select

В данном случае оператор Range(“A1”) – ключевое слово конструкции и не более.

Пусть мы выделили ячейку “С5” (Range(“C5”).Select), тогда имеем:

Range(“C5”).Select

ActiveCell.Offset(0,1).Range(“A1”).Select ‘Перейти к ячейке D5

(вправо на одну)

Range(“C5”).Select

ActiveCell.Offset(0,-1).Range(“A1”).Select ‘Перейти к ячейке B5

(влево на одну)

Range(“C5”).Select

ActiveCell.Offset(1,0).Range(“A1”).Select ‘Перейти к ячейке C6

(вниз на одну)

Range(“C5”).Select

ActiveCell.Offset(-1,0).Range(“A1”).Select ‘Перейти к ячейке C4

(вверх на одну)

3.4.2 Занесение в ячейку листа формул

Чтобы занести выражение в ячейку электронной таблицы необходимо:

  • адресоваться к ней способами, изложенными выше;

  • вызвать метод Formula.

Ниже приведены примеры для различных способов адресации к ячейке:

а) прямая ссылка на имя ячейки: Range(“A1”).Formula= ”=a1+a2”;

б) прямая ссылка на номер ячейки: Cells(1,1).Formula= “=a1+a2”;

в) косвенная ссылка на имя ячейки:

Range(“A1”).Select

ActiveCell.Formula= “=a1+a2”

г) косвенная ссылка на ячейку по приращению:

ActiveCell.Offset(0,1).Range(“A1”).Select

ActiveCell.Formula= “=a1+a2”

Непосредственно использовать в макросах на Visual Basic функций Excel можно через инструкцию WorksheetFunction.Имя_функции(список параметров). Параметр, содержащий ссылку на ячейку, оформляется как было изложено выше:

Dim a As Double

a=10+WorksheetFunction.Acos(Range(“A1”))

Вычисление ArcCos ячейки А1

a=10+WorksheetFunction.Acos(Cells(1,1))

Вычисление ArcCos ячейки А1

Для операций с группой ячеек достаточно указать их размещение в операторе Range(“A1:B3”):

a= WorksheetFunction.Min(Range(“A1:B3”))

Поиск минимального значения в блоке А1:В3

Для удобства используется оператор Set (присвоить), позволяющий назначить переменной типа Range область ячеек:

Dim ab As Range

Set ab=Workbooks(“Work.xls”).Worksheets(“Лист1”).Range(“A1:B3”)

a= WorksheetFunction.Min(ab)

Поиск минимального значения в блоке ячеек А1:В3

При вызове стандартных функций Visual Basic (Exp, Cos, Sin и т.д.) в качестве параметров нужно передавать только переменные или значения, определенные в макросе. При вызове функций Excel нужно передавать только ссылки на ячейки (инструкции Range, Cells).

3.5 Управляющие структуры

В Visual Basic, как и во всех языках программирования, существуют управляющие конструкции, предназначенные для управления порядком выполнения команд. Различают два основных типа управляющих операторов

  • if

  • Select Case

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

В свою очередь, управляющие операторы if бывают двух видов:

  • If...Then

  • If...Then...Else

Конструкция If...Then применяется, когда необходимо выполнить определенные действия в зависимости от некоторого условия. Управляющая конструкция If...Then...Else используется в том случае, когда необходимо выполнить разные действия в зависимости от условия.

Конструкция if.. .Then.. .Else аналогична конструкции if...Then, но позволяет задать действия, исполняемые как при выполнении условий, так и в случае их невыполнения.

Конструкция имеет следующий синтаксис:

IF условие Then .

Конструкции для обработки истинного условия

Else

Конструкции для обработки ложного условия

End If

Характеристики

Тип файла
Документ
Размер
6,31 Mb
Учебное заведение
Неизвестно

Список файлов ВКР

Свежие статьи
Популярно сейчас
Как Вы думаете, сколько людей до Вас делали точно такое же задание? 99% студентов выполняют точно такие же задания, как и их предшественники год назад. Найдите нужный учебный материал на СтудИзбе!
Ответы на популярные вопросы
Да! Наши авторы собирают и выкладывают те работы, которые сдаются в Вашем учебном заведении ежегодно и уже проверены преподавателями.
Да! У нас любой человек может выложить любую учебную работу и зарабатывать на её продажах! Но каждый учебный материал публикуется только после тщательной проверки администрацией.
Вернём деньги! А если быть более точными, то автору даётся немного времени на исправление, а если не исправит или выйдет время, то вернём деньги в полном объёме!
Да! На равне с готовыми студенческими работами у нас продаются услуги. Цены на услуги видны сразу, то есть Вам нужно только указать параметры и сразу можно оплачивать.
Отзывы студентов
Ставлю 10/10
Все нравится, очень удобный сайт, помогает в учебе. Кроме этого, можно заработать самому, выставляя готовые учебные материалы на продажу здесь. Рейтинги и отзывы на преподавателей очень помогают сориентироваться в начале нового семестра. Спасибо за такую функцию. Ставлю максимальную оценку.
Лучшая платформа для успешной сдачи сессии
Познакомился со СтудИзбой благодаря своему другу, очень нравится интерфейс, количество доступных файлов, цена, в общем, все прекрасно. Даже сам продаю какие-то свои работы.
Студизба ван лав ❤
Очень офигенный сайт для студентов. Много полезных учебных материалов. Пользуюсь студизбой с октября 2021 года. Серьёзных нареканий нет. Хотелось бы, что бы ввели подписочную модель и сделали материалы дешевле 300 рублей в рамках подписки бесплатными.
Отличный сайт
Лично меня всё устраивает - и покупка, и продажа; и цены, и возможность предпросмотра куска файла, и обилие бесплатных файлов (в подборках по авторам, читай, ВУЗам и факультетам). Есть определённые баги, но всё решаемо, да и администраторы реагируют в течение суток.
Маленький отзыв о большом помощнике!
Студизба спасает в те моменты, когда сроки горят, а работ накопилось достаточно. Довольно удобный сайт с простой навигацией и огромным количеством материалов.
Студ. Изба как крупнейший сборник работ для студентов
Тут дофига бывает всего полезного. Печально, что бывают предметы по которым даже одного бесплатного решения нет, но это скорее вопрос к студентам. В остальном всё здорово.
Спасательный островок
Если уже не успеваешь разобраться или застрял на каком-то задание поможет тебе быстро и недорого решить твою проблему.
Всё и так отлично
Всё очень удобно. Особенно круто, что есть система бонусов и можно выводить остатки денег. Очень много качественных бесплатных файлов.
Отзыв о системе "Студизба"
Отличная платформа для распространения работ, востребованных студентами. Хорошо налаженная и качественная работа сайта, огромная база заданий и аудитория.
Отличный помощник
Отличный сайт с кучей полезных файлов, позволяющий найти много методичек / учебников / отзывов о вузах и преподователях.
Отлично помогает студентам в любой момент для решения трудных и незамедлительных задач
Хотелось бы больше конкретной информации о преподавателях. А так в принципе хороший сайт, всегда им пользуюсь и ни разу не было желания прекратить. Хороший сайт для помощи студентам, удобный и приятный интерфейс. Из недостатков можно выделить только отсутствия небольшого количества файлов.
Спасибо за шикарный сайт
Великолепный сайт на котором студент за не большие деньги может найти помощь с дз, проектами курсовыми, лабораторными, а также узнать отзывы на преподавателей и бесплатно скачать пособия.
Популярные преподаватели
Добавляйте материалы
и зарабатывайте!
Продажи идут автоматически
6513
Авторов
на СтудИзбе
302
Средний доход
с одного платного файла
Обучение Подробнее