DATESINPERIOD函数
DATESINPERIOD函数隶属于“时间智能函数”,属于“表”函数。这个函数的功能很强大,用途方面也是比较广泛的。
用途1:可以用来返回固定的日期值。
用途2:可以用来算移动平均。
用途3:可以算固定日期内的累计值。
语法
DAX=
DATESINPERIOD(<日期列>,<开始日期>,<移动间隔>,<粒度>)
参数
日期列:包含日期的列。
开始日期:日期表达式作为初始日期。
移动间隔:正数向后平移,负数向前平移,遵守四舍五入。
粒度:年/季度/月/日。
返回结果
一个包含日期列的表。
示例
示例文件:
这是白茶随机模拟的数据,这里不做过多的赘述。
例子1:
DATESINPERIOD函数例子1 =
DATESINPERIOD ( '示例'[日期], MAX ( '示例'[日期] ), -7, DAY )
返回结果为最大日期往前算7天的日期。
例子2:
DATESINPERIOD函数例子2 =
DATESINPERIOD ( '示例'[日期], MIN ( '示例'[日期] ), -7, DAY )
返回结果为最小日期。
这里就涉及到DATESINPERIOD这个函数的注意点了:返回的日期如果在原表中没有的话,那么呈现的结果就是原表日期值的最大值/最小值。
也就是你想返回的范围必须在原表范围内。
例子3:
DATESINPERIOD例子3 =
AVERAGEX (
DATESINPERIOD ( '示例'[日期], MAX ( '示例'[日期] ), -7, DAY ),
CALCULATE ( SUM ( '示例'[销售] ) )
)
结果:
这组代码返回的结果为近7日的销售平均值。之前白茶写过移动平均的文章,这里就不赘述了,感兴趣的小伙伴可以翻翻往期文章。
例子4:
DATESINPERIOD例子4 =
CALCULATE (
SUM ( '示例'[销售] ),
DATESINPERIOD ( '示例'[日期], MAX ( '示例'[日期] ), -5, DAY )
)
结果:
这组代码求得是最近5天的销售额累计情况,也是属于移动累计的模式。
小伙伴们,GET了么?
白茶会不定期的分享一些函数卡片哦。
ID:Storysming