Vba excel диапазон дат

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

Функция Date

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

Синтаксис

Пример

Sub PrimerDate()

    MsgBox «Сегодня: « & Date

End Sub

Функция DateAdd

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

Синтаксис

DateAdd(interval, number, date)

Параметры

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

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

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

Пример

Sub PrimerDateAdd()

    MsgBox «31.01.2021 + 1 месяц = « & DateAdd(«m», 1, «31.01.2021») ‘Результат: 28.02.2021

    MsgBox «Сегодня + 3 года = « & DateAdd(«yyyy», 3, Date)

    MsgBox «Сегодня — 2 недели = « & DateAdd(«ww», 2, Date)

    MsgBox «10:22:14 + 10 минут = « & DateAdd(«n», 10, «10:22:14») ‘Результат: 10:32:14

End Sub

Функция DateDiff

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

Синтаксис

DateDiff(interval, date1, date2, [firstdayofweek], [firstweekofyear])

Параметры

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

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

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

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

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

Пример

Sub PrimerDateDiff()

‘Даже если между датами соседних лет разница 1 день,

‘DateDiff с интервалом «y» покажет разницу — 1 год

    MsgBox DateDiff(«y», «31.12.2020», «01.01.2021») ‘Результат: 1 год

    MsgBox DateDiff(«d», «31.12.2020», «01.01.2021») ‘Результат: 1 день

    MsgBox DateDiff(«n», «31.12.2020», «01.01.2021») ‘Результат: 1440 минут

    MsgBox «Полных лет с начала века = « & DateDiff(«y», «2000», Year(Now) 1)

End Sub

Функция DatePart

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

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

Синтаксис

DatePart(interval, date, [firstdayofweek], [firstweekofyear])

Параметры

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

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

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

Пример

Sub PrimerDatePart()

    MsgBox DatePart(«y», «31.12.2020») ‘Результат: 366

    MsgBox DatePart(«yyyy», CDate(43685)) ‘Результат: 2019

    MsgBox DatePart(«n», CDate(43685.45345)) ‘Результат: 52

    MsgBox «День недели по счету сегодня = « & DatePart(«w», Now, vbMonday)

End Sub

Функция DateSerial

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

Синтаксис

DateSerial(year, month, day)

Параметры

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

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

Пример

Sub PrimerDateSerial()

    MsgBox DateSerial(2021, 2, 10) ‘Результат: 10.02.2020

    MsgBox DateSerial(2020, 1, 400) ‘Результат: 03.02.2021

End Sub

Разберем подробнее строку 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 года.

Пример

Sub PrimerDateValue()

    MsgBox DateValue(«8 марта 2021») ‘Результат: 08.03.2021

    MsgBox DateValue(«17 мая 2021 0:59:15») ‘Результат: 17.05.2021

End Sub

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

Функция Day

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

Синтаксис

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

Пример

Sub PrimerDay()

    MsgBox Day(Now)

End Sub

Функция IsDate

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

Синтаксис

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

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

Пример

Sub PrimerIsDate()

    MsgBox IsDate(«18 апреля 2021») ‘Результат: True

    MsgBox IsDate(«31 февраля 2021») ‘Результат: False

    MsgBox IsDate(«4.10.20 11:12:54») ‘Результат: True

End Sub

Функция Hour

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

Синтаксис

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

Пример

Sub PrimerHour()

    MsgBox Hour(Now)

    MsgBox Hour(«22:36:54»)

End Sub

Функция Minute

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

Синтаксис

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

Пример

Sub PrimerMinute()

    MsgBox Minute(Now)

    MsgBox Minute(«22:36:54»)

End Sub

Функция Month

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

Синтаксис

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

Пример

Sub PrimerMonth()

    MsgBox Month(Now)

End Sub

Функция MonthName

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

Синтаксис

MonthName(month, [abbreviate])

Параметры

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

Пример

Sub PrimerMonthName()

    MsgBox MonthName(10) ‘Результат: Октябрь

    MsgBox MonthName(10, True) ‘Результат: окт

End Sub

Функция Now

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

Синтаксис

Пример

Sub PrimerNow()

    MsgBox Now

    MsgBox Day(Now)

    MsgBox Hour(Now)

End Sub

Функция Second

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

Синтаксис

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

Пример

Sub PrimerSecond()

    MsgBox Second(Now)

    MsgBox Second(«22:30:14»)

End Sub

Функция Time

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

Синтаксис

Пример

Sub PrimerTime()

    MsgBox «Текущее время: « & Time

End Sub

Функция TimeSerial

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

Синтаксис

TimeSerial(hour, minute, second)

Параметры

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

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

Пример

Sub PrimerTime()

    MsgBox TimeSerial(5, 16, 4) ‘Результат: 5:16:04

    MsgBox TimeSerial(5, 75, 158) ‘Результат: 6:17:38

End Sub

Разберем подробнее строку 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 включительно.

Пример

Sub PrimerTimeValue()

    MsgBox TimeValue(«6:45:37 PM») ‘Результат: 18:45:37

    MsgBox TimeValue(«17 мая 2021 3:59:15 AM») ‘Результат: 3:59:15

End Sub

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

Функция Weekday

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

Синтаксис

Weekday(date, [firstdayofweek])

Параметры

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

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

Пример

Sub PrimerWeekday()

    MsgBox Weekday(«23 апреля 2021», vbMonday) ‘Результат: 5

    MsgBox Weekday(202125, vbMonday) ‘Результат: 6

End Sub

Функция WeekdayName

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

Синтаксис

WeekdayName(weekday, [abbreviate], [firstdayofweek])

Параметры

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

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

Пример

Sub PrimerWeekdayName()

    MsgBox WeekdayName(3, True, vbMonday) ‘Результат: Ср

    MsgBox WeekdayName(3, , vbMonday) ‘Результат: среда

    MsgBox WeekdayName(Weekday(Now, vbMonday), , vbMonday)

End Sub

Функция Year

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

Синтаксис

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

Пример

Sub PrimerYear()

    MsgBox Year(Now)

End Sub

Приложение 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 Первая полная неделя года.

 

shupike

Пользователь

Сообщений: 12
Регистрация: 13.05.2021

#1

13.05.2021 16:57:00

Добрый день! Подскажите, плиз — нужно при помощи формы задавать диапазон дат и в выбранном диапазоне заполнять лист рандомными датами. Сначала сделал вот так, без формы:
Range(«A1:A50»).Formula = «=RANDBETWEEN(DATE(2018,1,1),DATE(2020,1,1))»
Просто проверить чтобы. Добавил форму, набросал 2 Date Picker’а — рядом кнопка «Считать». Забираю значения дат и надо бы их передать в RANDBETWEEN, но не пойму, в каком формате это делается. То есть если —

Код
Private Sub CommandButton1_Click()
date1 = DTPicker1.Value
date2 = DTPicker2.Value
Range("A1:A50").Formula = "=RANDBETWEEN(date1,date2)"
End Sub

ничего не получается. Как правильно передать значение в данном случае? Заранее благодарен :-)

 

New

Пользователь

Сообщений: 4581
Регистрация: 06.01.2013

#2

13.05.2021 17:58:51

Код
Range("A1:A50").Formula = "=RANDBETWEEN(" & date1 & "," & date2 & ")"
 

DANIKOLA

Пользователь

Сообщений: 422
Регистрация: 17.08.2019

#3

13.05.2021 18:31:08

Здравствуйте. У меня так работает:

Код
Private Sub CommandButton1_Click()
    Dim date1 As Date, date2 As Date, Cell As Range
    date1 = DTPicker1.Value
    date2 = DTPicker2.Value
    
    For Each Cell In Selection ' Range("A1:A50")
        Cell.NumberFormat = "m/d/yyyy"
        Cell = Application.WorksheetFunction.RandBetween(date1, date2)
    Next Cell
End Sub

Сделал для выделенной области, если не хотите, то замените Selection, на Range.

P.S. Один не приятный момент есть — элемент формы DTPicker работает не во всех версиях Excel.

Прикрепленные файлы

  • RndDate.xlsm (19.78 КБ)
  • DTPiker.PNG (27.42 КБ)

Изменено: DANIKOLA13.05.2021 18:48:58

 

_Igor_61

Пользователь

Сообщений: 3007
Регистрация: 18.07.2016

#4

13.05.2021 19:12:41

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

Не знаю, насколько это соответствует истине, цитата

отсюда

shupike, если эта задача чисто теоретическая или для набирания опыта — все ОК.
Но если таким путем Вы собираетесь решать практические задачи…
Excel ОЧЕНЬ хорошее средство для решения определенных задач, но не все задачи можно решить с помощью лишь одного EXCEL
Поэтому лучше бы Вы объяснили, для чего нужно решение поставленной Вами задачи, тогда бы и решение было бы правильней :)

Изменено: _Igor_6113.05.2021 19:16:46

 

New

Пользователь

Сообщений: 4581
Регистрация: 06.01.2013

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

Изменено: New13.05.2021 20:35:47

 

shupike

Пользователь

Сообщений: 12
Регистрация: 13.05.2021

#6

14.05.2021 10:24:42

Цитата
New написал:
1Range(«A1:A50»).Formula = «=RANDBETWEEN(» & date1 & «,» & date2 & «)»

Выдает вот такую ошибку:

javascript: void(0)

;

Прикрепленные файлы

  • randbetween_error.jpg (47.34 КБ)

 

Jack Famous

Пользователь

Сообщений: 10848
Регистрация: 07.11.2014

OS: Win 8.1 Корп. x64 | Excel 2016 x64: | Browser: Chrome

#7

14.05.2021 11:36:18

OFF

Цитата
New: все случайные числа в компьютере — псевдо случайны

если пользователь не может точно сказать, какое значение при рандомайзе он получит, то это достаточно случайное значение — всё остальное из разряда философии

Изменено: Jack Famous14.05.2021 11:36:29

Во всех делах очень полезно периодически ставить знак вопроса к тому, что вы с давних пор считали не требующим доказательств (Бертран Рассел) ►Благодарности сюда◄

 

shupike

Пользователь

Сообщений: 12
Регистрация: 13.05.2021

#8

14.05.2021 12:15:26

Спасибо, сделал в итоге так:

Код
Private Sub CommandButton1_Click()
Dim date1 As Date, date2 As Date, Cell As Range
    date1 = DTPicker1.Value
    date2 = DTPicker2.Value
    
    For Each Cell In Selection
        Cell.NumberFormat = "[$-FC19]dd mmmm yyyy г.;@"
        Cell = Application.WorksheetFunction.RandBetween(date1, date2)
    Next Cell
End Sub

Даты нужно вставлять в виде «14 мая 2021 г.»

Содержание

  1. VBA – установить диапазон между двумя датами с помощью функции поиска
  2. VBA Excel. Автоматическое заполнение интервала дат (периода)
  3. Диалоговое окно для выбора периода
  4. Пример диалогового окна для выбора периода
  5. Открытие диалогового окна с заполненным периодом
  6. VBA Excel. Функции для работы с датой и временем
  7. Функция Date
  8. Функция DateAdd
  9. Функция DateDiff
  10. Функция DateSerial
  11. Синтаксис
  12. Замечания
  13. Пример
  14. См. также
  15. Поддержка и обратная связь
  16. DateDiff function
  17. Syntax
  18. Settings
  19. Remarks
  20. Example
  21. See also
  22. Support and feedback

VBA – установить диапазон между двумя датами с помощью функции поиска

Я пытаюсь получить код VBA для поиска по столбцу для введенного пользователем значения (в форме) и установить диапазон на основе значений.

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

Но это не работает так, как я ожидал, и это ошибка. (Изменение: WS определен, поэтому я знаю, что это не проблема). Я даже не знаю, правильно ли я это сделаю

Я чувствую себя побежденным 🙁

Любая помощь будет оценена, спасибо заранее!

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

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

Мне нужно иметь возможность обрабатывать даты обработки, которые не отображаются в базе данных, мне также нужен сценарий, чтобы иметь возможность “пропустить” даты, которые не существуют. Т.е., 1-й 1-й, 3-й, 3-й, 5-й. Если мои начальные и конечные даты были 1-го и 5-го, весь пример был бы диапазоном.

Спасибо за вашу помощь до сих пор, ребята, я ценю это!

Я попробовал несколько ответов и добавил это в свой код, но теперь он терпит неудачу в Range_Global.

Давайте начнем с этого и посмотрим, что нужно подгонять. Этот код будет искать дату (на основе ввода) и найти позицию этой даты в столбце. То же самое с “EndDate”, а затем создает диапазон в этом столбце между двумя позициями.

Другой подход должен подразумевать поиск EndDate снизу вверх (как в значениях столбцов Excel) и для StartDate сверху вниз. как это:

И третий (прелесть): для EndDate сверху вниз и для StartDate сверху вниз. как это:

На моем домашнем ноутбуке поиск на 30 000 ячеек мгновен (до 1 с). Попробуйте, и на основе обратной связи мы можем ее точно настроить.

С другой стороны, я мог бы прочитать ваш вопрос, как искать. Чтобы выбрать не все значения между верхней/нижней позицией, но любые ячейки со значениями дат между двумя входными значениями никогда не повторяют расположение значений в списке (ячейки столбцов), т.е. если StartDate = 1.Jan.2013 и EndDate = 3.Jan.2013. Код должен подбирать 1,2 и 3 из списка 30.000, которые никогда не останавливаются на позиции этих 3 дат (которые фактически могут быть найдены тысячи раз). Если это верно, решение может быть проще, чем выше.

Использование Find – это правильный способ сделать это, вам просто нужно получить несколько подробностей.

Используйте Set чтобы назначить ссылки диапазона. Например, Set StartRange =. (и убедитесь, что Dim StartRange as Range ). Ditto EndRange и SearchRange

Укажите ячейку After . Обратите внимание, что по умолчанию это верхняя левая ячейка диапазона поиска, и поиск начинается после этой ячейки. Если ваш StartDate находится в ячейке A1 (и другой ячейке), а затем по умолчанию возвращает неверный результат

Ограничьте диапазон поиска интересующей колонкой.

Dim все переменные. Каждому variaqble нужен собственный As (и использовать Option Explicit )

Мне не нравится концепция этой даты поиска по нескольким причинам..

  • Он делает предположение, что даты всегда будут в порядке
  • Он делает предположение, что обе даты будут существовать в списке

Хотя в этом случае это могут быть допустимые предположения, я уверен, что могут быть случаи, когда это может быть не так…

Я не знаю, как это сделать, но одна альтернатива – использование автофильтра

Источник

VBA Excel. Автоматическое заполнение интервала дат (периода)

Автоматическое заполнение интервала дат при открытии диалогового окна для выбора периода, а также при нажатии кнопок: «Сегодня», «Вчера», «Этот месяц», «Прошлый месяц», «Прошлый год» с помощью VBA Excel. Скачать файл с примером.

Диалоговое окно для выбора периода

Автоматическое заполнение интервала дат в VBA Excel рассмотрим на примере диалогового окна, прообраз которого использовался на практике для выбора периода формирования отчета о сданной выручке в разрезе торговых точек. Правда, кнопка выбора интервала дат была только для прошлого месяца, а открывалась форма с предзаполненными датами текущего месяца, остальные периоды устанавливались вручную, но ими почти не приходилось пользоваться.

Пример диалогового окна для выбора периода

Диалоговое окно для выбора периода

Для вызова пользовательской формы используется вставленная на рабочий лист кнопка из панели «Элементы ActiveX». Расположить ее лучше на закрепленной верхней строке листа, чтобы кнопка не уезжала за пределы экрана при прокрутке.

Итак, перечислим названия объектов (элементов управления), которые будут задействованы в приведенных примерах кода:

  • пользовательская форма (диалоговое окно выбора периода) — UserForm1;
  • текстовое поле для ввода начальной даты — TextBox1;
  • текстовое поле для ввода конечной даты — TextBox2;
  • кнопка «Сегодня» — CommandButton1;
  • кнопка «Вчера» — CommandButton2;
  • кнопка «Текущий месяц» — CommandButton3;
  • кнопка «Прошлый месяц»* — CommandButton4;
  • кнопка «Прошлый год»** — CommandButton5;
  • кнопка для вызова диалогового окна, расположенная на рабочем листе — Button1***.

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

Открытие диалогового окна с заполненным периодом

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

Источник

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

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

Функция Date

Синтаксис

Пример

Функция DateAdd

Синтаксис

Параметры

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

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

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

Пример

Функция DateDiff

Синтаксис

Параметры

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

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

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

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

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

Источник

Функция DateSerial

Возвращает результат функции Variant (Date) для указанного года, месяца и дня.

Синтаксис

DateSerial(год, месяц, день)

Синтаксис функции DateSerial включает следующие именованные аргументы:

Part Описание
year Обязательный аргумент типа Integer. Число от 100 до 9999 включительно или числовое выражение.
month Обязательный аргумент типа Integer. Любое числовое выражение.
День Обязательный аргумент типа Integer. Любое числовое выражение.

Замечания

Чтобы указать дату, например 31 декабря 1991 г., диапазон чисел для каждого аргумента DateSerial должен находиться в допустимом диапазоне для единицы. то есть 1–31 для дней и 1–12 месяцев. Однако можно также указать относительные даты для каждого аргумента с помощью любого числового выражения, представляющего некоторое количество дней, месяцев или лет до или после определенной даты.

В следующем примере вместо абсолютных чисел даты используются числовые выражения. Здесь функция DateSerial возвращает дату, которая является за день до первого дня ( 1 — 1 ), за два месяца до августа ( 8 — 2 ), за 10 лет до 1990 года ( 1990 — 10 ); другими словами, 31 мая 1980 г.

В операционных системах Windows 98 и Windows 2000 двузначные года в аргументе год интерпретируются в соответствии с параметрами, определяемыми пользователем. Согласно стандартным параметрам значения от 0 до 29 включительно интерпретируются как 2000–2029 гг. Значения по умолчанию от 30 до 99 интерпретируются как 1930–1999 гг. Для всех остальных значений аргумента год используются четырехзначные числа (например, 1800).

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

Если один из аргументов превышает допустимый предел, увеличивается значение следующего аргумента. Например, если указано значение 35 дней, оно рассматривается как один месяц и определенное количество дней, зависящее от конкретного месяца. Если хотя бы один аргумент выходит за пределы от -32768 до 32767, возникает ошибка. Если указанная тремя аргументами дата выходит за допустимые пределы для дат, также возникает ошибка.

Для года, месяца и дня, если свойство Calendar имеет значение григорианского, предполагается, что указанное значение будет григорианским. Если для свойства Calendar указано значение «Hijri», указанные значения считаются датой по календарю Хиджра.

Возвращаемая часть даты выражается в единицах времени текущего календаря Visual Basic. Например, если выбран календарь Хиджра, и необходимо вернуть значение года, будет возвращено значение по календарю Хиджра. Для года аргумента значения от 0 до 99 включительно интерпретируются как годы 1400–1499. Для всех остальных значений аргумента год используйте полные четырехзначные числа (например, 1520).

Пример

В этом примере функция DateSerial используется для получения даты для указанного года, месяца и дня.

См. также

Поддержка и обратная связь

Есть вопросы или отзывы, касающиеся Office VBA или этой статьи? Руководство по другим способам получения поддержки и отправки отзывов см. в статье Поддержка Office VBA и обратная связь.

Источник

DateDiff function

Returns a Variant (Long) specifying the number of time intervals between two specified dates.

Syntax

DateDiff(interval, date1, date2, [ firstdayofweek, [ firstweekofyear ]] )

The DateDiff function syntax has these named arguments:

Part Description
interval Required. String expression that is the interval of time you use to calculate the difference between date1 and date2.
date1, date2 Required; Variant (Date). Two dates you want to use in the calculation.
firstdayofweek Optional. A constant that specifies the first day of the week. If not specified, Sunday is assumed.
firstweekofyear Optional. A constant that specifies the first week of the year. If not specified, the first week is assumed to be the week in which January 1 occurs.

Settings

The interval argument has these settings:

Setting Description
yyyy Year
q Quarter
m Month
y Day of year
d Day
w Weekday
ww Week
h Hour
n Minute
s Second

The firstdayofweek argument has these settings:

Constant Value Description
vbUseSystem 0 Use the NLS API setting.
vbSunday 1 Sunday (default)
vbMonday 2 Monday
vbTuesday 3 Tuesday
vbWednesday 4 Wednesday
vbThursday 5 Thursday
vbFriday 6 Friday
vbSaturday 7 Saturday

The firstweekofyear argument has these settings:

Constant Value Description
vbUseSystem 0 Use the NLS API setting.
vbFirstJan1 1 Start with week in which January 1 occurs (default).
vbFirstFourDays 2 Start with the first week that has at least four days in the new year.
vbFirstFullWeek 3 Start with first full week of the year.

Use the DateDiff function to determine how many specified time intervals exist between two dates. For example, you might use DateDiff to calculate the number of days between two dates, or the number of weeks between today and the end of the year.

To calculate the number of days between date1 and date2, you can use either Day of year («y») or Day («d»). When interval is Weekday («w»), DateDiff returns the number of weeks between the two dates. If date1 falls on a Monday, DateDiff counts the number of Mondays until date2. It counts date2 but not date1.

If interval is Week («ww»), however, the DateDiff function returns the number of calendar weeks between the two dates. It counts the number of Sundays between date1 and date2. DateDiff counts date2 if it falls on a Sunday; but it doesn’t count date1, even if it does fall on a Sunday.

If date1 refers to a later point in time than date2, the DateDiff function returns a negative number. The firstdayofweek argument affects calculations that use the «w» and «ww» interval symbols.

If date1 or date2 is a date literal, the specified year becomes a permanent part of that date. However, if date1 or date2 is enclosed in double quotation marks (» «), and you omit the year, the current year is inserted in your code each time the date1 or date2 expression is evaluated. This makes it possible to write code that can be used in different years.

When comparing December 31 to January 1 of the immediately succeeding year, DateDiff for Year («yyyy») returns 1 even though only a day has elapsed.

For date1 and date2, if the Calendar property setting is Gregorian, the supplied date must be Gregorian. If the calendar is Hijri, the supplied date must be Hijri.

Example

This example uses the DateDiff function to display the number of days between a given date and today.

See also

Support and feedback

Have questions or feedback about Office VBA or this documentation? Please see Office VBA support and feedback for guidance about the ways you can receive support and provide feedback.

Источник

Baykal555

1 / 1 / 0

Регистрация: 08.09.2017

Сообщений: 391

1

Поиск дат в заданном диапазоне

19.07.2018, 21:34. Показов 5572. Ответов 6

Метки нет (Все метки)


Студворк — интернет-сервис помощи студентам

Всех приветствую!

Задача следующая: есть список дат. Необходимо, чтобы пользователь вводил две даты (дата начальная и дата конечная), а программа выводила те даты из списка, которые подходят под этот диапазон и копировала их в соседний столбец. Начальную дату в коде я обозначил переменной «а», дату конечную — переменной «n» (см. вложения). Получилось вот так:

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
Sub data()
Dim i As Integer
Dim a As Integer
Dim n As Integer
 
a = "20.01.2017"
n = "30.01.2017"
 
For i = 10 To 21
 
If n < Cells(i, 4) > a Then Cells(i, 4).Copy
 
Cells(i, 5).PasteSpecial
Next
 
End Sub

Помогите, пожалуйста, в чем ошибка?

Заранее огромное спасибо!

Вложения

Тип файла: xlsx поиск даты .xlsx (9.0 Кб, 16 просмотров)



0



pashulka

4131 / 2235 / 940

Регистрация: 01.12.2010

Сообщений: 4,624

19.07.2018, 21:58

2

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
Dim r&, startDate As Date, endDate As Date
 
startDate = #1/20/2017#
endDate = #1/30/2017#
 
Application.ScreenUpdating = False
Range("E10:E21").Clear
Range("E10:E21").NumberFormat = "dd/mm/yyyy"
 
For r = 10 To 21
    Select Case Cells(r, 4)
        Case startDate To endDate: Cells(r, 5) = Cells(r, 4)
    End Select
Next
Application.ScreenUpdating = True

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
Dim startDate As Date, endDate As Date, r&, arr As Variant
 
startDate = #1/20/2017#
endDate = #1/30/2017#
 
arr = Range("D10:D21").Value
 
For r = 1 To UBound(arr)
    Select Case arr(r, 1)
        Case startDate To endDate
        Case Else: arr(r, 1) = Empty
    End Select
Next
 
Range("E10:E21") = arr



0



1 / 1 / 0

Регистрация: 08.09.2017

Сообщений: 391

19.07.2018, 22:42

 [ТС]

3

Спасибо!
Решил привязать выбор даты к форме, но выходит ошибка:

Private Sub CommandButton1_Click()
Dim startDate As Date, endDate As Date, r&, arr As Variant

startDate = UserForm1.TextBox1.Value
endDate = UserForm1.TextBox2.Value

в чем причина?



0



Alexey2014

96 / 84 / 49

Регистрация: 17.09.2014

Сообщений: 670

19.07.2018, 22:45

4

Baykal555, попробуйте

Visual Basic
1
startDate = CDate(UserForm1.TextBox1.Value)



0



pashulka

4131 / 2235 / 940

Регистрация: 01.12.2010

Сообщений: 4,624

19.07.2018, 22:54

5

CDate «нужна» только как правило хорошего тона, ибо если в текстовом поле будет не дата, то данная функция «рухнет», так что нужна предварительная проверка IsDate, например

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
Private Sub CommandButton1_Click()
 
Dim startDate As Date, endDate As Date, r&, arr As Variant
 
startDate = CDate(TextBox1)
endDate = CDate(TextBox2)
 
...
 
End Sub
 
Private Sub TextBox1_Exit(ByVal Cancel As MSForms.ReturnBoolean)
    Cancel = Not IsDate(TextBox1)
End Sub
 
Private Sub TextBox2_Exit(ByVal Cancel As MSForms.ReturnBoolean)
    Cancel = Not IsDate(TextBox2)
End Sub



0



Burk

1813 / 1135 / 346

Регистрация: 11.07.2014

Сообщений: 4,002

20.07.2018, 10:13

6

Baykal555, а разве ВБА на эту строку не ругалась?

Цитата
Сообщение от Baykal555
Посмотреть сообщение

If n < Cells(i, 4) > a Then Cells(i, 4).Copy

Надо так записывать условие (оно у вас логически и программно неправильно)

Visual Basic
1
2
3
4
a = CDate("20.01.2017")
n = CDate("30.01.2017")
 
If  Cells(i, 4) > a and  Cells(i, 4)  < n Then Cells(i, 5)= Cells(i, 4)

и 13 строку убрать, можно обойтись и без Copy

Добавлено через 12 минут
Лучше

Visual Basic
1
Cells(i, 5)= Format(Cells(i, 4),"dd.mm.yyyy")

или действительно копированием



0



1 / 1 / 0

Регистрация: 08.09.2017

Сообщений: 391

20.07.2018, 15:04

 [ТС]

7

Спасибо большое!



0



На чтение 6 мин. Просмотров 7.9k.

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

Уровень мастерства: Средний

VBA AutoFilter Automate Date Filters

Содержание

  1. Скачать файл
  2. Фильтры даты в Excel
  3. Фильтры диапазона дат в VBA
  4. Несколько групп дат
  5. Динамические даты в периодах
  6. Фильтры и типы данных

Скачать файл

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

VBA AutoFilters Guide.xlsm (100.5 KB)

У нас есть много вариантов при фильтрации столбца, который
содержит даты. Список выпадающего меню фильтра группирует даты по годам,
месяцам, дням, часам, минутам, секундам. Мы можем расширить и установить эти
флажки для фильтрации нескольких элементов.

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

Давайте посмотрим на некоторые примеры кода для различных
фильтров даты.

При
применении фильтра для одного числа нам нужно использовать форматирование чисел,
которое применяется в столбце. Это странная причуда VBA, которая
может привести к неточным результатам, если вы не знаете правила. В приведенном
ниже коде есть пример.

Фильтры диапазона дат в VBA

Следующий макрос содержит примеры основных фильтров даты. Важно отметить, что значения параметров Criteria заключены в кавычки. Операторы сравнения = <> также включены в кавычки.
Пожалуйста, ознакомьтесь с моей статьей Фильтрация сводной таблицы или среза по самой последней дате или периоду для получения более подробной информации о том, как использовать метод AutoFilter и его параметры.

Вы можете скопировать / вставить приведенный ниже код в VB Editor.

Sub AutoFilter_Date_Examples()
' Примеры фильтрации столбцов с датами
 
Dim lo As ListObject
Dim iCol As Long

  ' Установить ссылку на первую таблицу на листе
  Set lo = Sheet1.ListObjects(1)
  
  ' Установить поле фильтра
  iCol = lo.ListColumns("Date").Index
   
  ' Очистить фильтры
  lo.AutoFilter.ShowAllData

  With lo.Range
      
    ' Одиночная дата - использовать тот же формат даты, который 
     'применяется к столбцу
    .AutoFilter Field:=iCol, Criteria1:="=1/2/2014"
    
    'До даты
    .AutoFilter Field:=iCol, Criteria1:="<1/31/2014"
    
    'После или равно дате
    .AutoFilter Field:=iCol, Criteria1:=">=1/31/2014"
    
    'Диапазон дат (между датами)
    .AutoFilter Field:=iCol, _
                        Criteria1:=">=1/1/2014", _
                        Operator:=xlAnd, _
                        Criteria2:="<=12/31/2015"
                      
End Sub

Несколько групп дат

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

Для этих фильтров мы устанавливаем для параметра Operator
значение xlFilterValues. Мы используем Criteria2 (не Criteria1), чтобы указать
массив элементов с помощью функции Array.

Это специальный массив шаблонов, где первое число — это
период времени (год, месяцы, дни и т. Д.). Второе число — последняя дата в
диапазоне. Макрос ниже содержит примеры и дальнейшие пояснения.

Sub AutoFilter_Multiple_Dates_Examples()
'Примеры фильтрации столбцов для нескольких периодов времени даты
 
Dim lo As ListObject
Dim iCol As Long

  'Установить ссылку на первую таблицу на листе
  Set lo = Sheet1.ListObjects(1)
  
  'Установить поле фильтра
  iCol = lo.ListColumns("Date").Index
   
  'Очистить фильтры
  lo.AutoFilter.ShowAllData

  With lo.Range

    'При фильтрации по нескольким периодам, выбранным из
    'раскрывающегося меню фильтра, используйте Operator: = xlFilterValues и
    'Критерии2 с узорным массивом. Первое число - 
    'временной период. Второе число - последняя дата в периоде.
    
    'Первое измерение массива - группа периода времени
      '0-Годы
      '1-Месяцы
      '2-Дни
      '3-Часы
      '4-Минуты
      '5-Секунды
    
    
    'Несколько лет (2014 и 2016) использовать последний день времени
    'периода для каждого элемента массива
    .AutoFilter Field:=iCol, _
                Operator:=xlFilterValues, _
                Criteria2:=Array(0, "12/31/2014", 0, "12/31/2016")
    
    'Несколько месяцев (январь, апрель, июль, октябрь 2015 года)
    .AutoFilter Field:=iCol, _
                Operator:=xlFilterValues, _
                Criteria2:=Array(1, "1/31/2015", 1, "4/30/2015", 1, "7/31/2015", 1, "10/31/2015")
    
    'Несколько дней
    'Последний день каждого месяца: январь, апрель, июль, октябрь 2015 года)
    .AutoFilter Field:=iCol, _
                Operator:=xlFilterValues, _
                Criteria2:=Array(2, "1/31/2015", 2, "4/30/2015", 2, "7/31/2015", 2, "10/31/2015")
    
    'Установить поле фильтра
     iCol = lo.ListColumns("Date Time").Index
     
    'Очистить фильтры
    lo.AutoFilter.ShowAllData
    
    'Несколько часов» (все даты в 11:00 часов 10 января 2008 г.
    'и 11:00 часов 20.01.2008)
    
    .AutoFilter Field:=iCol, _
                Operator:=xlFilterValues, _
                Criteria2:=Array(3, "1/10/2018 13:59:59", 3, "1/20/2018 23:59:59")
  
  End With
  
End Sub

Динамические даты в периодах

Следующий макрос содержит примеры дат в определенных
периодах. Это аналогично выбору предустановленных элементов фильтра из подменю «Фильтры
даты».

Для этих фильтров мы устанавливаем параметр Operator равным
xlFilterDynamic. Мы устанавливаем Criteria1 в константу, которая представляет
параметр периода динамической даты. Константы перечислены ниже.

Sub AutoFilter_Dates_in_Period_Examples()
'Примеры фильтрации столбцов для ДАТЫ В ПЕРИОД
'Пресеты фильтров даты, найденные в подменю «Фильтры даты
 
Dim lo As ListObject
Dim iCol As Long

  'Установить ссылку на первую таблицу на листе
  Set lo = Sheet1.ListObjects(1)
  
  'Установить поле фильтра
  iCol = lo.ListColumns("Date").Index
   
  'Очистить фильтры
  lo.AutoFilter.ShowAllData
  
  'Оператор: = xlFilterDynamic
  'Критерии1: = одно из следующих перечислений
  
  ' Значение константы
  ' 1     xlFilterToday
  ' 2     xlFilterYesterday
  ' 3     xlFilterTomorrow
  ' 4     xlFilterThisWeek
  ' 5     xlFilterLastWeek
  ' 6     xlFilterNextWeek
  ' 7     xlFilterThisMonth
  ' 8     xlFilterLastMonth
  ' 9     xlFilterNextMonth
  ' 10    xlFilterThisQuarter
  ' 11    xlFilterLastQuarter
  ' 12    xlFilterNextQuarter
  ' 13    xlFilterThisYear
  ' 14    xlFilterLastYear
  ' 15    xlFilterNextYear
  ' 16    xlFilterYearToDate
  ' 17    xlFilterAllDatesInPeriodQuarter1
  ' 18    xlFilterAllDatesInPeriodQuarter2
  ' 19    xlFilterAllDatesInPeriodQuarter3
  ' 20    xlFilterAllDatesInPeriodQuarter4
  ' 21    xlFilterAllDatesInPeriodJanuary
  ' 22    xlFilterAllDatesInPeriodFebruray <- февраль написан с ошибкой
  ' 23    xlFilterAllDatesInPeriodMarch
  ' 24    xlFilterAllDatesInPeriodApril
  ' 25    xlFilterAllDatesInPeriodMay
  ' 26    xlFilterAllDatesInPeriodJune
  ' 27    xlFilterAllDatesInPeriodJuly
  ' 28    xlFilterAllDatesInPeriodAugust
  ' 29    xlFilterAllDatesInPeriodSeptember
  ' 30    xlFilterAllDatesInPeriodOctober
  ' 31    xlFilterAllDatesInPeriodNovember
  ' 32    xlFilterAllDatesInPeriodDecember
      
  With lo.Range
    
    'Все даты в январе (по всем годам)
    .AutoFilter Field:=iCol, _
                Operator:=xlFilterDynamic, _
                Criteria1:=xlFilterAllDatesInPeriodJanuary

    'Все даты во втором квартале (по всем годам)
    .AutoFilter Field:=iCol, _
                Operator:=xlFilterDynamic, _
                Criteria1:=xlFilterAllDatesInPeriodQuarter2
  
  End With

End Sub

Вот ссылка на справочную страницу MSDN со списком XlDynamicFilterCriteria. И спасибо Дугу Глэнси из YourSumBuddy за то, что он указал на февральскую опечатку в константе. У него есть несколько полезных советов для параметра Operator в этой статье.

Фильтры и типы данных

Параметры
раскрывающегося меню фильтра изменяются в зависимости от типа данных в столбце.
У нас есть разные фильтры для текста, чисел, дат и цветов. Это создает МНОГО
различных комбинаций операторов и критериев для каждого типа фильтра.

Я создал отдельные статьи для каждого из этих типов фильтров. Статьи содержат пояснения и примеры кода VBA.

  • Как очистить фильтры с помощью VBA
  • Как отфильтровать пустые и непустые ячейки
  • Как фильтровать числа с помощью VBA
  • Как фильтровать текст с помощью VBA
  • Как отфильтровать цвета и значки с помощью VBA

Файл в разделе загрузок выше содержит все эти примеры кода в одном месте. Вы можете добавить его в свою личную книгу макросов и использовать макросы в своих проектах.

Пожалуйста, оставьте
комментарий ниже с любыми вопросами или предложениями. Спасибо!

Понравилась статья? Поделить с друзьями:
  • Vba excel диапазон выделенных строк
  • Vba excel диапазон в одномерный массив
  • Vba excel диалоговое окно выбора файла
  • Vba excel диалоговое окно ввода данных
  • Vba excel диалог да нет