
加入 PowerBI自己学 知识星球:下载源文件,边学边练;遇到问题,提问交流,有问必答。
度量值的天性是按照筛选上下文实现动态计算,动态计算靠的就是CALCULATE,每个度量值都用到了CALCULATE,因此CALCULATE可以称之为核心函数。很多度量值的表达式中并没有出现CALCULATE,比如销售额=SUM(表[Sales]),其实是度量值自带筛选上下文,默认省略了CALCULATE而已。
语法
CALCULATE(<expression>[, <filter1> [, <filter2> [, …]]])
用途
1 筛选上下文开关,将行上下文转换为筛选上下文,用于计算列或SUMX等迭代函数。
以SUMX函数第二参数的一个小坑为例,有如下表格,求每个客户的最大值之和。

SUMX第二参数放上不带CALCULATE的表达式,会出现错误的结果。因为行上下文未对MAX('Table'[数量])中的Table起到筛选作用,所以SUMX第一参数的每一行客户都取了一个全表数量的最大值。

最低0.47元/天 解锁文章
1万+

被折叠的 条评论
为什么被折叠?



