Excel DAX - анализ времени
DAX имеет важную и мощную функцию, называемую Time Intelligence. Логика времени позволяет писать формулы DAX, которые ссылаются на периоды времени для использования в сводных таблицах.
DAX имеет 35 функций анализа времени, специально предназначенных для агрегирования и сравнения данных с течением времени. Однако эти функции DAX имеют некоторые ограничения на данные, которые необходимо понимать и работать с осторожностью, чтобы избежать ошибок.
Почему Time Intelligence делает DAX мощным?
Функции логики операций со временем работают с данными, которые постоянно меняются в зависимости от контекста, который вы выбираете в сводных таблицах и визуализациях Power View. Как вы знаете, большая часть анализа данных включает суммирование данных за периоды времени, сравнение значений данных за периоды времени, понимание тенденций и принятие решений на основе будущих прогнозов.
Например, вы можете захотеть просуммировать суммы продаж за последний месяц по продуктам и сравнить их с итогами за другие месяцы финансового года. Это означает, что вы должны использовать даты как способ группировки и агрегирования транзакций продаж за определенный период времени.
Здесь вы можете увидеть мощь DAX. Вы можете использовать функции аналитики времени DAX для определения вычисляемых полей, которые помогут вам анализировать данные с течением времени, без необходимости изменять выбор даты в сводных таблицах. Это облегчит вашу работу. Более того, вы можете создавать сводные таблицы, что было бы невозможно иначе.
Требования к функциям DAX Time Intelligence
Функции логики времени DAX предъявляют определенные требования. Если эти требования не соблюдены, вы можете получить ошибки или они могут работать некорректно. Следовательно, вы также можете ссылаться на эти требования как на правила или ограничения. Ниже приведены определенные требования / правила / ограничения функций DAX:
В вашей модели данных должна быть таблица дат.
Таблица дат должна включать столбец, который DAX считает столбцом даты. Вы можете назвать столбец так, как хотите, но он должен соответствовать следующим условиям: o Столбец даты должен содержать непрерывный набор дат, охватывающий каждый день в период времени, в который вы анализируете данные.
Каждая дата должна существовать один раз и только один раз в столбце даты.
Вы не можете пропустить какие-либо даты (например, вы не можете пропустить даты выходных).
Функции аналитики времени DAX работают только в стандартном календаре и предполагают, что начало года - 1 января, а конец года - 31 декабря, с месяцами в году и днями в каждом месяце календарного года.
Однако вы можете настроить стандартный календарь на разные финансовые годы. Перед тем, как использовать функцию временной разведки, рекомендуется проверить вышеуказанные требования.
Дополнительные сведения о таблицах дат и их использовании в формулах DAX см. В учебнике = Моделирование данных с помощью DAX в этой библиотеке руководств.
Функции DAX Time Intelligence - Категории
Функции DAX Time Intelligence можно разделить на следующие категории:
- Функции DAX, возвращающие одну дату.
- Функции DAX, возвращающие таблицу дат.
- Функции DAX, которые оценивают выражения за период времени.
Функции DAX, возвращающие одну дату
Функции DAX в этой категории возвращают одну дату.
В этой категории 10 функций DAX -
Sr. No. | Функция DAX и возвращаемое значение |
---|---|
1 | FIRSTDATE (Date_Column) Возвращает первую дату в Date_Column в текущем контексте. |
2 | LASTDATE (Date_Column) Возвращает последнюю дату в Date_Column в текущем контексте. |
3 | FIRSTNONBLANK (Date_Column, Expression) Возвращает первую дату, в которой выражение имеет непустое значение. |
4 | LASTNONBLANK (Date_Column, Expression) Возвращает последнюю дату, когда выражение имеет непустое значение. |
5 | STARTOFMONTH (Date_Column) Возвращает первую дату месяца в текущем контексте. |
6 | ENDOFMONTH (Date_Column) Возвращает последнюю дату месяца в текущем контексте. |
7 | STARTOFQUARTER (Date_Column) Возвращает первую дату квартала в текущем контексте. |
8 | ENDOFQUARTER (Date_Column) Возвращает последнюю дату квартала в текущем контексте. |
9 | STARTOFYEAR (Date_Column, [YE_Date]) Возвращает первую дату года в текущем контексте. |
10 | ENDOFYEAR (Date_Column, [YE_Date]) Возвращает последнюю дату года в текущем контексте. |
Функции DAX, возвращающие таблицу дат
Функции DAX в этой категории возвращают таблицу дат. Эти функции в основном будут использоваться в качестве аргумента SetFilter для функции DAX - CALCULATE.
В этой категории 16 функций DAX. Восемь (8) из этих функций DAX - это «предыдущая» и «следующая» функции.
Функции «предыдущий» и «следующий» начинаются со столбца даты в текущем контексте и вычисляют предыдущий или следующий день, месяц, квартал или год.
«Предыдущие» функции работают в обратном направлении от первой даты в текущем контексте, а «следующие» функции перемещаются вперед от последней даты в текущем контексте.
Функции «предыдущая» и «следующая» возвращают результирующие даты в виде таблицы с одним столбцом.
Sr. No. | Функция DAX и возвращаемое значение |
---|---|
1 | PREVIOUSDAY (Date_Column) Возвращает таблицу, содержащую столбец всех дат, представляющих день, предшествующий первой дате в Date_Column в текущем контексте. |
2 | NEXTDAY (Date_Column) Возвращает таблицу, содержащую столбец всех дат со следующего дня, исходя из первой даты, указанной в Date_Column в текущем контексте. |
3 | PREVIOUSMONTH (Date_Column) Возвращает таблицу, содержащую столбец всех дат за предыдущий месяц на основе первой даты в Date_Column в текущем контексте. |
4 | NEXTMONTH (Date_Column) Возвращает таблицу, содержащую столбец всех дат следующего месяца на основе первой даты в Date_Column в текущем контексте. |
5 | PREVIOUSQUARTER (Date_Column) Возвращает таблицу, содержащую столбец всех дат за предыдущий квартал на основе первой даты в Date_Column в текущем контексте. |
6 | NEXTQUARTER (Date_Column) Возвращает таблицу, содержащую столбец всех дат следующего квартала на основе первой даты, указанной в Date_Column в текущем контексте. |
7 | PREVIOUSYEAR (Date_Column, [YE_Date]) Возвращает таблицу, содержащую столбец всех дат за предыдущий год, учитывая последнюю дату в Date_Column в текущем контексте. |
8 | NEXTYEAR (Date_Column, [YE_Date]) Возвращает таблицу, содержащую столбец всех дат в следующем году на основе первой даты в Date_Column в текущем контексте. |
Четыре (4) функции DAX вычисляют набор дат в периоде. Эти функции выполняют вычисления, используя последнюю дату в текущем контексте.
Sr. No. | Функция DAX и возвращаемое значение |
---|---|
1 | DATESMTD (Date_Column) Возвращает таблицу, содержащую столбец дат за месяц до текущей даты в текущем контексте. |
2 | DATESQTD (Date_Column) Возвращает таблицу, содержащую столбец дат текущего квартала в текущем контексте. |
3 | DATESYTD (Date_Column, [YE_Date]) Возвращает таблицу, содержащую столбец дат текущего года в текущем контексте. |
4 | SAMEPERIODLASTYEAR (Date_Column) Возвращает таблицу, содержащую столбец дат, сдвинутых на год назад по сравнению с датами в указанном Date_Column в текущем контексте. Note- SAMEPERIODLASTYEAR требует, чтобы текущий контекст содержал непрерывный набор дат. Если текущий контекст не является непрерывным набором дат, SAMEPERIODLASTYEAR вернет ошибку. |
Четыре (4) функции DAX используются для перехода от набора дат, которые находятся в текущем контексте, к новому набору дат.
Эти функции DAX более мощные, чем предыдущие.
Функции DAX - DATEADD, DATESINPERIOD и PARALLELPERIOD сдвигают некоторое количество временных интервалов из текущего контекста. Интервал может быть днем, месяцем, кварталом или годом, представленный ключевыми словами - ДЕНЬ, МЕСЯЦ, КВАРТАЛ и ГОД соответственно.
Например:
Сдвинуть назад на 2 дня.
Двигайтесь вперед на 5 месяцев.
Двигайтесь вперед на один месяц с сегодняшнего дня.
Вернитесь к тому же кварталу прошлого года.
Функция DAX - DATESBETWEEN вычисляет набор дат между указанной датой начала и датой окончания.
Если аргумент функции - количество интервалов (целочисленное значение) положительный, сдвиг вперед, а если отрицательный, сдвиг назад.
Sr. No. | Функция DAX и возвращаемое значение |
---|---|
1 | DATEADD (Date_Column, Number_of_Intervals, Interval) Возвращает таблицу, содержащую столбец дат, сдвинутых вперед или назад во времени на указанное количество интервалов от дат в текущем контексте. |
2 | DATESINPERIOD (Date_Column, Start_Date, Number_of_Intervals, Interval) Возвращает таблицу, содержащую столбец дат, который начинается с start_date и продолжается в течение указанного числа_интервалов. |
3 | PARALLELPERIOD (Date_Column, Number_of_Intervals, Interval) Возвращает таблицу, содержащую столбец дат, представляющий период, параллельный датам в указанном Date_Column в текущем контексте, с датами, сдвинутыми на несколько интервалов вперед или назад во времени. |
4 | DATESBETWEEN (Date_Column, Start_Date, End_Date) Возвращает таблицу, содержащую столбец дат, который начинается с start_date и продолжается до end_date. |
Функции DAX, оценивающие выражения за определенный период времени
Функции DAX в этой категории оценивают выражение за указанный период времени.
В этой категории девять (9) функций DAX -
Три (3) функции DAX в этой категории могут использоваться для оценки любого заданного выражения за определенный период времени.
Sr. No. | Функция DAX и возвращаемое значение |
---|---|
1 | TOTALMTD (Expression, Date_Column, [SetFilter]) Оценивает значение выражения для дат в месяце до даты в текущем контексте. |
2 | TOTALQTD (Expression, Date_Column, [SetFilter]) Оценивает значение выражения для дат в квартале до даты в текущем контексте. |
3 | TOTALYTD (Expression, Date_Column, [SetFilter], [YE_Date]) Оценивает значение выражения для дат в текущем году в текущем контексте |
Шесть (6) функций DAX в этой категории могут использоваться для расчета начального и конечного сальдо.
Начальное сальдо для любого периода такое же, как конечное сальдо для предыдущего периода.
Конечный баланс включает все данные до конца периода, а начальный баланс не включает никаких данных за текущий период.
Эти функции DAX всегда возвращают значение выражения, оцененного для определенного момента времени.
Момент времени, который нам важен, всегда является последним возможным значением даты в календарном периоде.
Начальное сальдо основывается на последней дате предыдущего периода, тогда как конечное сальдо основывается на последней дате в текущем периоде.
Текущий период всегда определяется последней датой в контексте текущей даты.
Sr. No. | Функция DAX и возвращаемое значение |
---|---|
1 | OPENINGBALANCEMONTH (Expression, Date_Column, [SetFilter]) Оценивает выражение в первое число месяца в текущем контексте. |
2 | CLOSINGBALANCEMONTH (Expression, Date_Column, [SetFilter]) Оценивает выражение в последний день месяца в текущем контексте. |
3 | OPENINGBALANCEQUARTER (Expression, Date_Column, [SetFilter]) Оценивает выражение в первую дату квартала в текущем контексте. |
4 | CLOSINGBALANCEQUARTER (Expression, Date_Column, [SetFilter]) Оценивает выражение на последнюю дату квартала в текущем контексте. |
5 | OPENINGBALANCEYEAR (Expression, Date_Column, [SetFilter], [YE_Date]) Оценивает выражение в первую дату года в текущем контексте. |
6 | CLOSINGBALANCEYEAR (Expression, Date_Column, [SetFilter], [YE_Date]) Оценивает выражение в последний день года в текущем контексте. |