Перейти к содержимому
Наше приложение «Дешевые авиабилеты» в AppGallery >>

VBA Excel. Функции для работы с датой и временем

    Функции для работы с датой и временем в VBA Excel. Синтаксис, параметры, спецсимволы, примеры. Функции, возвращающие текущие дату и время по системному таймеру.

    Функция Date

    Date – это функция, которая возвращает значение текущей системной даты. Тип возвращаемого значения – Variant/Date.

    Синтаксис

    Пример

    Функция DateAdd

    DateAdd – это функция, которая возвращает результат прибавления к дате указанного интервала времени. Тип возвращаемого значения – Variant/Date.

    Синтаксис

    Параметры

    Параметр Описание
    interval Обязательный параметр. Строковое выражение из спецсимволов, представляющее интервал времени, который требуется добавить.
    number Обязательный параметр. Числовое выражение, задающее количество интервалов, которые необходимо добавить. Может быть как положительным (возвращается будущая дата), так и отрицательным (возвращается предыдущая дата).
    date Обязательный параметр. Значение типа Variant/Date или литерал, представляющий дату, к которой должен быть добавлен интервал.

    Таблицу аргументов (значений) параметра interval смотрите в параграфе «Приложение 1».

    Примечание к таблице аргументов: три символа – y, d, w – указывают функции DateAdd на один день, который необходимо прибавить к исходной дате number раз.

    Пример

    Функция DateDiff

    DateDiff – это функция, которая возвращает количество указанных интервалов времени между двумя датами. Тип возвращаемого значения – Variant/Long.

    Синтаксис

    Параметры

    Параметр Описание
    interval Обязательный параметр. Строковое выражение из спецсимволов, представляющее интервал времени, количество которых (интервалов) требуется вычислить между двумя датами.
    date1, date2 Обязательные параметры. Значения типа Variant/Date, представляющие две даты, между которыми вычисляется количество указанных интервалов.
    firstdayofweek Необязательный параметр. Константа, задающая первый день недели. По умолчанию – воскресенье.
    firstweekofyear Необязательный параметр. Константа, задающая первую неделю года. По умолчанию – неделя, в которую входит 1 января.

    Таблицу аргументов (значений) параметра interval смотрите в параграфе «Приложение 1».

    Примечание к таблице аргументов: в отличие от функции DateAdd, в функции DateDiff спецсимвол "w", как и "ww", обозначает неделю. Но расчет осуществляется по разному. Подробнее об этом на сайте разработчиков.

    Параметры firstdayofweek и firstweekofyear определяют правила расчета количества недель между датами.

    Таблицы констант из коллекций firstdayofweek и firstweekofyear смотрите в параграфах «Приложение 2» и «Приложение 3».

    Пример

    Функция DatePart

    DatePart – это функция, которая возвращает указанную часть заданной даты. Тип возвращаемого значения – Variant/Integer.

    Есть предупреждение по использованию этой функции.

    Синтаксис

    Параметры

    Параметр Описание
    interval Обязательный параметр. Строковое выражение из спецсимволов, представляющее часть даты, которую требуется извлечь.
    date Обязательные параметры. Значение типа Variant/Date, представляющее дату, часть которой следует извлечь.
    firstdayofweek Необязательный параметр. Константа, задающая первый день недели. По умолчанию – воскресенье.
    firstweekofyear Необязательный параметр. Константа, задающая первую неделю года. По умолчанию – неделя, в которую входит 1 января.

    Таблицу аргументов (значений) параметра interval смотрите в параграфе «Приложение 1». В третьей графе этой таблицы указаны интервалы значений, возвращаемых функцией DatePart.

    Таблицы констант из коллекций firstdayofweek и firstweekofyear смотрите в параграфах «Приложение 2» и «Приложение 3».

    Пример

    Функция DateSerial

    DateSerial – это функция, которая возвращает значение даты для указанного года, месяца и дня. Тип возвращаемого значения – Variant/Date.

    Синтаксис

    Параметры

    Параметр Описание
    year Обязательный параметр типа Integer. Числовое выражение, возвращающее значение от 100 до 9999 включительно.
    month Обязательный параметр типа Integer. Числовое выражение, возвращающее любое значение (в пределах Integer), а не только от 1 до 12.*
    day Обязательный параметр типа Integer. Числовое выражение, возвращающее любое значение (в пределах Integer), а не только от 1 до 31.*

    * Функция DateSerial автоматически пересчитывает общее количество дней в полные месяцы и остаток, общее количество месяцев в полные годы и остаток (подробнее в примере).

    Пример

    Разберем подробнее строку DateSerial(2020, 1, 400):

    • 400 дней = 366 дней + 31 день + 3 дня;
    • 366 дней = 1 год, так как по условию month:=1, значит февраль 2020 входит в расчет, а в нем – 29 дней;
    • 31 день = 1 месяц, так как сначала заполняется январь (по условию month:=1);
    • 3 дня – остаток.

    В итоге получается:

    DateSerial(2020+1, 1+1, 3) = DateSerial(2021, 2, 3)

    Функция DateValue

    DateValue – это функция, которая преобразует дату, указанную в виде строки, в значение типа Variant/Date (время игнорируется).

    Синтаксис

    Параметр date – строковое выражение, представляющее дату с 1 января 100 года по 31 декабря 9999 года.

    Пример

    Функция DateValue игнорирует время, указанное в преобразуемой строке, но если время указано в некорректном виде (например, «10:60:60»), будет сгенерирована ошибка.

    Функция Day

    Day – это функция, которая возвращает день месяца в виде числа от 1 до 31 включительно. Тип возвращаемого значения – Variant/Integer.

    Синтаксис

    Параметр date – любое числовое или строковое выражение, представляющее дату.

    Пример

    Функция IsDate

    IsDate – это функция, которая возвращает True, если выражение является датой или распознается как допустимое значение даты или времени. В остальных случаях возвращается значение False.

    Синтаксис

    Параметр expression – это переменная, возвращающая дату или строковое выражение, распознаваемое как дата или время.

    Значение, возвращаемое переменной expression, не должно выходить из диапазона допустимых дат: от 1 января 100 года до 31 декабря 9999 года (для Windows).

    Пример

    Функция Hour

    Hour – это функция, которая возвращает количество часов в виде числа от 0 до 23 включительно. Тип возвращаемого значения – Variant/Integer.

    Синтаксис

    Параметр time – любое числовое или строковое выражение, представляющее время.

    Пример

    Функция Minute

    Minute – это функция, которая возвращает количество минут в виде числа от 0 до 59 включительно. Тип возвращаемого значения – Variant/Integer.

    Синтаксис

    Параметр time – любое числовое или строковое выражение, представляющее время.

    Пример

    Функция Month

    Month – это функция, которая возвращает день месяца в виде числа от 1 до 12 включительно. Тип возвращаемого значения – Variant/Integer.

    Синтаксис

    Параметр date – любое числовое или строковое выражение, представляющее дату.

    Пример

    Функция MonthName

    MonthName – это функция, которая возвращает название месяца в виде строки.

    Синтаксис

    Параметры

    Параметр Описание
    month Обязательный параметр. Числовое обозначение месяца от 1 до 12 включительно.
    abbreviate Необязательный параметр. Логическое значение: True – возвращается сокращенное название месяца, False (по умолчанию) – название месяца не сокращается.

    Пример

    Функция Now

    Now – это функция, которая возвращает текущую системную дату и время. Тип возвращаемого значения – Variant/Date.

    Синтаксис

    Пример

    Функция Second

    Second – это функция, которая возвращает количество секунд в виде числа от 0 до 59 включительно. Тип возвращаемого значения – Variant/Integer.

    Синтаксис

    Параметр time – любое числовое или строковое выражение, представляющее время.

    Пример

    Функция Time

    Time – это функция, которая возвращает значение текущего системного времени. Тип возвращаемого значения – Variant/Date.

    Синтаксис

    Пример

    Функция TimeSerial

    TimeSerial – это функция, которая возвращает значение времени для указанного часа, минуты и секунды. Тип возвращаемого значения – Variant/Date.

    Синтаксис

    Параметры

    Параметр Описание
    hour Обязательный параметр типа Integer. Числовое выражение, возвращающее значение от 0 до 23 включительно.
    minute Обязательный параметр типа Integer. Числовое выражение, возвращающее любое значение (в пределах Integer), а не только от 0 до 59.*
    second Обязательный параметр типа Integer. Числовое выражение, возвращающее любое значение (в пределах Integer), а не только от 0 до 59.*

    * Функция TimeSerial автоматически пересчитывает общее количество секунд в полные минуты и остаток, общее количество минут в полные часы и остаток (подробнее в примере).

    Пример

    Разберем подробнее строку TimeSerial(5, 75, 158):

    • 158 секунд = 120 секунд (2 минуты) + 38 секунд;
    • 75 минут = 60 минут (1 час) + 15 минут.

    В итоге получается:

    TimeSerial(5+1, 15+2, 38) = TimeSerial(6, 17, 38)

    Функция TimeValue

    TimeValue – это функция, которая преобразует время, указанное в виде строки, в значение типа Variant/Date (дата игнорируется).

    Синтаксис

    Параметр time – строковое выражение, представляющее время с 0:00:00 по 23:59:59 включительно.

    Пример

    Функция TimeValue игнорирует дату, указанную в преобразуемой строке, но если дата указана в некорректном виде (например, «30.02.2021»), будет сгенерирована ошибка.

    Функция Weekday

    Weekday – это функция, которая возвращает день недели в виде числа от 1 до 7 включительно. Тип возвращаемого значения – Variant/Integer.

    Синтаксис

    Параметры

    Параметр Описание
    date Обязательный параметр. Любое выражение (числовое, строковое), отображающее дату.
    firstdayofweek Константа, задающая первый день недели. По умолчанию – воскресенье.

    Таблицу констант из коллекции firstdayofweek смотрите в параграфе «Приложение 2».

    Пример

    Функция WeekdayName

    WeekdayName – это функция, которая возвращает название дня недели в виде строки.

    Синтаксис

    Параметры

    Параметр Описание
    weekday Обязательный параметр. Числовое обозначение дня недели от 1 до 7 включительно.
    abbreviate Необязательный параметр. Логическое значение: True – возвращается сокращенное название дня недели, False (по умолчанию) – название дня недели не сокращается.
    firstdayofweek Константа, задающая первый день недели. По умолчанию – воскресенье.

    Таблицу констант из коллекции firstdayofweek смотрите в параграфе «Приложение 2».

    Пример

    Функция Year

    Year – это функция, которая возвращает номер года в виде числа. Тип возвращаемого значения – Variant/Integer.

    Синтаксис

    Параметр date – любое числовое или строковое выражение, представляющее дату.

    Пример

    Приложение 1

    Таблица аргументов (значений) параметраinterval для функций DateAdd, DateDiff и DatePart:

    Аргумент Описание Интервал значений
    yyyy Год 100 – 9999
    q Квартал 1 – 4
    m Месяц 1 – 12
    y День года 1 – 366
    d День месяца 1 – 31
    w День недели 1 – 7
    ww Неделя 1 – 53
    h Часы 0 – 23
    n Минуты 0 – 59
    s Секунды 0 – 59

    В третьей графе этой таблицы указаны интервалы значений, возвращаемых функцией DatePart.

    Приложение 2

    Константы из коллекции firstdayofweek:

    Константа Значение Описание
    vbUseSystem 0 Используются системные настройки
    vbSunday 1 Воскресенье (по умолчанию)
    vbMonday 2 Понедельник
    vbTuesday 3 Вторник
    vbWednesday 4 Среда
    vbThursday 5 Четверг
    vbFriday 6 Пятница
    vbSaturday 7 Суббота

    Приложение 3

    Константы из коллекции firstweekofyear:

    Константа Значение Описание
    vbUseSystem 0 Используются системные настройки.
    vbFirstJan1 1 Неделя, в которую входит 1 января (по умолчанию).
    vbFirstFourDays 2 Неделя, в которую входит не менее четырех дней нового года.
    vbFirstFullWeek 3 Первая полная неделя года.

    Содержание рубрики VBA Excel по тематическим разделам со ссылками на все статьи.

    31 комментарий для “VBA Excel. Функции для работы с датой и временем”

    1. Здравствуйте!
      А как правильно перевести целое число секунд в сутки:часы:минуты:секунды?
      (или хотя бы отобразить через MsgBox)
      Т.е. например, перевести 113745 в 1 сутки 7 часов 35 минут 45 секунд
      Использую просто деление, но думаю, что наверняка есть более удобный способ
      Спасибо!

      1. Евгений

        Добрый вечер!
        Мне удалось создать такую конструкцию:

        Работает со значением переменной в интервале от 0 до 2147483646 (max cmBut = max Long — 1).

    2. B ячейке D3 записана дата 30.04.1997
      как получить числовое значение без года
      т.е. мне надо получить дату 30.04.1900
      В числовом значении это будет 121
      * формульное решение: =ДАТА(0;МЕСЯЦ(D3);ДЕНЬ(D3))

    3. Здравствуйте!
      Дана дата в виде строки в американском формате месяц/день/
      год. Нужно переделать ее в русский формат день.месяц.год.
      примерное решение — Format(InputBox("Ввод даты", "Ввод", "01/01/2018"), "dd.mm.yyyy")

    4. Татьяна

      Добрый день! Отдаю файл ексель с кодом vba над которым работала пол года руководству. Дополнительные программы для защиты не использую. Код просто под паролем. Возникла идея назначить выполнения макросов до определенной даты. Как вы думаете это хорошая идея? Волнует именно, что руководство «забудет о моей напряженной работе».

      1. Евгений

        Здравствуйте, Татьяна!
        Идея очень хорошая, если нет возможности сначала передать демо-вариант с ограниченной функциональностью. Лично мне не приходилось ограничивать работу VBA, но я бы в данной ситуации, как вы и предлагаете, использовал бы ограничение по дате. Возможно, кроме напоминания о необходимости оплаты, я бы еще добавил код, удаляющий один из стандартных модулей. Ограничивающую дату, чтобы не бросалась в глаза, лучше отобразить в виде числа:

    5. Сбитый Лётчик Небосводов

      Здравствуйте!
      «Функция Time – это функция, которая возвращает значение текущей системной даты.»
      Наверное, всё же времени.

      1. Евгений

        Здравствуйте!
        Согласен, была опечатка.

    6. Добрый день!
      подскажите пожалуйста, а как перевести Tuesday, March 01 2022 в формат 01.03.2022

      1. Евгений

        Добрый день, Максим!
        Для этого есть функция DateSerial. Но есть одна проблемка — в русскоязычной версии Excel с помощью конструкции Month(CDate("1 " & StringMonth)) можно преобразовать в число только месяц строкой на русском языке. Поэтому для перевода названия месяца в число будем использовать словарь:

        1. Евгений, благодарю!
          протестировал, работает. но в итоге реализовал через питон.

    7. Алексей

      Здравствуйте, Евгений. Есть старая конструкция кода:

      не могу заставить работать эту строку: If Date > #6/11/2022# Then
      оставляю файл с необходимой датой, а строка не работает. Захожу в файл, закрываю… не удаляется.
      Принудительно запускаю, тогда только удаляет книгу, автоматически — нет.

      1. Евгений

        Здравствуйте, Алексей!
        Попробуйте так:

    8. Алексей

      Здравствуйте, Евгений.
      Не работает. Такое впечатление, что у меня, библиотека не подключена. Но на сколько я понимаю здесь они не нужны.

      1. Евгений

        Добрый день!
        У меня Excel 2016, код работает: книга удаляется, остается только «пустой» экземпляр приложения. Код размещается в модуле книги.

        1. Алексей

          Здравствуйте, Евгений. У меня тоже 2016. Ничего не мог сделать (запустить работу макроса) пока не отправил на другой компьютер и оттуда обратно (свой компьютер я и обновлял, и перезагружал). Как пришёл файл заработал присланный и старые пробные версии файлов в которых был установлен этот код. Не знаю, что было.

    9. Георгий

      Здравствуйте, Евгений. Подскажите как получить текущую дату в американском стиле (22.12.01, привык сохранять файлы/папки с таким именем, для удобной сортировки по времени).
      MsgBox Year(Now) & "." & Month(Now) & "." & Day(Now) результат 2022.12.1 (как оставить только 22 и добавить 0 к числу?)

      1. Евгений

        Добрый день, Георгий!
        MsgBox Format(Now, "YY.MM.DD")

    10. Валерка

      Здравствуйте, у меня немного иная ситуация, как с ней бороться — не знаю )
      Может подскажите как текущую системную дату NOW() конвертировать в UNIX?

      Нужно для парсера, примерно что-то в таком виде: If tralala < Now() Then

      Спасибо! )

    11. Виталий

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

      1. Евгений

        Здравствуйте, Виталий!
        А где вы собираетесь брать исходные данные для вычисления рабочего времени между двумя датами?

    12. Добрый день! есть 2 даты: 30.04.2022 и 31.07.2022. Нужно сравнить месяц и год (т.е 04.2022 07.2022). Как правильно записать?

      1. Евгений

        Здравствуйте, Марина!
        Вот два варианта извлечения месяца и года из даты:

    13. Добрый день, подскажите, как сделать, чтобы после обновления макроса в конкретной ячейке на листе прописывалось время его обновления?

      1. Евгений

        Здравствуйте, Мария!
        Вставьте эту строку в ваш макрос перед End Sub:

    Обсуждение закрыто.