DAX进阶-死磕Calculate之1:改变筛选上下文之忽略(”删“)
小勤:在文章《DAX入门:无动态,不智能——谈谈DAX函数的计算环境(筛选上下文)问题》里提到,默认情况下度量的计算是随着计算环境(筛选上下文)的选择而动态变化的,但有时候就是需要一些不变的情况,那怎么办?大海:对的,实际工作中,经常会碰到这种情况,所以我们要让DAX能修改现有的计值上下文,不过,改变现有计值上下文的情况比较多,比如全部忽略、忽略一部分、用新的覆盖掉原来的、在原来的基础上再增加……小勤:啊!没想到情况还有这么多……大海:其实,总结起来就是“增”、“删”、“改”。小勤:对哦。那具体是怎样的?大海:在DAX函数里,Calculate函数就是为我们提供这样的功能的。我们先从简单的开始,一样一样慢慢来。我们先来看“删”的,比如我们现在有一个度量是这样的:
我们在数据透视表里,这个量会随着行列维度(筛选上下文)而变化,结果如下:
如果我们要把这些筛选上下文去掉,即销售量不随相应的行列维度(筛选上下文)而变化,那么,我们就需要把这些影响计算的上下文给去掉(可以理解为“删”),这时就可以用Calculate函数加All函数来完成,度量如下:
我们把这个度量也放到透视表里看看:
小勤:这样两个维度都不起作用了。大海:对的,也就是说,原来对影响度量计算相关的维度(筛选上下文)都被忽略(“删”)掉了。小勤:那如果我们只需要忽略掉一部分呢?大海:那我们就在All函数里写清楚要忽略的具体字段,比如我们写一个度量,只忽略销售人员的:
放到数据透视表里看看:
小勤:为什么其中只有B和C产品的忽略了销售人员呢?比如A产品的为什么不都是100呢?大海:不是只有B和C产品忽略了,维度A产品和销售人员小勤的组合为空,是这种维度组合不存在。小勤:原来这样。那如果需要忽略多个字段呢?大海:All函数是支持多个参数的,你自己试试?小勤:好,我大概想到了。【热门文章】1个Excel文件,30+个案例表,日常函数50+个全搞定66篇Excel Power Query干货文章,助你666从入门到全面实战!神一般的数据分析案例之一:高手在民间从身份证号码提取相关信息,你还在纠结用什么公式?真的out了!Power Query和超级表结合,实现文件夹及文档管理怎么在Excel中截图?这是我常用的几种方法!