52953.fb2
Предположим, что кто-то заставил вас убрать звания в конце каждой из вышеприведенных строк. Имена в списке имеют разную длину, так что готовые функции задачу не решают.
Но если предположить, что оригинальное имя содержится в переменной str-Старая, то поможет следующий трюк:
strНовая = Left(strСтарая, Len(strСтарая) - 7)
Если бы VBA читал книги вместо программного кода, я объяснил бы ему, что эти действия можно выполнить следующим образом.
1. Сначала вызывается функция Len, которая вычисляет длину оригинальной строки.
2. Из результата, полученного в п. 1, вычитается 7, поскольку каждое из званий занимает семь символов в конце строки (включая запятую и пробел).
В результате получится число, которому должна быть равна длина новой строки.
3. Вызывается функция Left, использующая вычисленную длину в качестве значения второго аргумента.
Функция Left читает столько символов, сколько задано вторым аргументом, из строки, указанной первым аргументом, возвращая только эти прочитанные символы.
4. Новая, более короткая строка, возвращенная функцией Left, присваивается переменной
Продолжая работать с новым списком уже без званий, предположим, что теперь вас попросили извлечь имена с отчествами и поместить их в новый список. Эту задачу можно выполнить с помощью следующего оператора:
strMMfl = Mid (strHoBafl, InStr (str-Новая, ",") + 2)
Функция Mid извлекает символы из любого места в строке, которую вы укажете в виде аргумента. Второй же аргумент этой функции говорит, с какого места в этой строке следует начать извлечение символов. В данном случае этот аргумент представляет собой выражение, состоящее из функции InStr плюс 2.
Функция InStr ищет в заданной строке (первый аргумент) другую строку (второй аргумент).
В данном случае второй аргумент - это запятая, которая в списке следует за фамилией. Значение, которое возвращает InStr, соответствует номеру позиции в первой строке, где встречается вторая строка, - теперь вы знаете, где заканчивается фамилия.
К значению, возвращенному функцией InStr, добавляется 2, чтобы пропустить запятую и следующий за ней пробел и найти позицию, с которой начинается имя. Теперь функция Mid извлечет символы, начиная с этого места и до конца строки (поскольку не указан третий, необязательный аргумент длина).
В реальном программировании работе с датами и временем отводится далеко не последняя, а часто и главная роль. Поэтому VBA предлагает ряд операторов и функций, позволяющих выяснить текущие время и дату, проводить вычисления с датами и извлекать из переменных со значениями дат различные компоненты типа времени, года или дня недели.
В табл. 11.4 представлено описание таких команд. У некоторых функций в этой таблице опущены необязательные аргументы - вы всегда сможете уточнить детали по справке VBA.
После таблицы несколько наиболее важных команд, относящихся к датам и времени, рассматриваются подробнее.
Чтобы воспользоваться предоставляемым здесь материалом, вы должны ясно представлять, как VBA обрабатывает значения дат и времени и как работать с переменными, хранящими даты (см. главу 7).
Таблица 11.4. Операторы и функции для работы с датами и временем
При задании аргументов не забывайте заключать буквальные значения дат в пару символов #, а строковые значения типа интервалов дат - в кавычки.
Имя | Тип | Выполняемые действия (для операторов) или возвращаемые значения (для функций) |
Date | Функция | Текущая системная дата |
Date (дата) | Оператор | Устанавливает системную дату по значению аргумента дата |
DateAdd (интервал, число, дата) | Функция | Новое значение даты, равное сумме исходной даты и казенного числа заданных интервалов даты или времени |
DateDiff (интервал, дата1, дата2) | Функция | Число указанных интервалов даты или времени, помещающихся в отрезке времени между датами 1 и 2 |
DatePart (интервал, дата) | функция | Целое значение, представляющее указанный интервал даты |
DateSerial (год, месяц, день) | Функция | Значение даты, определяемое аргументами год, месяц, день, которые должны быть числовыми |
DateValue (строка с датой) | Функция | Значение даты, соответствующее строке с датой |
Day (дата) | Функция | Целое значение, соответствующее дню месяца, заданного датой |
|