样例数据:
1. ALL
A. 语法
ALL( {<table> | <column>[, <column>[, <column>[,…]]]} )
位置 | 参数 | 描述 |
---|---|---|
第1参数 | table | 需要清除过滤器的表 |
第1参数 | column | 需要清除过滤器的列 |
可选重复第2参数 | column |
B. 返回
表——包含已经删除过滤器后的一列或多列的表。
C. 注意事项
- 通常和filter组合,如果是列名需要是filter处理的列名
- 1个参数只能写1个条件,列和表不能同时出现。
- 函数不单独使用,必须和其他函数配合
D. 作用
忽略指定过滤器后进行计算。
E. 案例
- 如果要忽略全部筛选条件,则第一参数使用表名来进行。所以
All('表1')
代表了忽略表中全部筛选条件,也就是求全班的平均成绩。
全班平均成绩:=Calculate(Average('表1'[成绩]),All('表1'))
- 如果要忽略的是表中的某一个维度,则第一参数使用列名来进行,所以
All('表1'[学科])
代表了只忽略学科这个维度去求学生的平均分。因为表里面有3个维度,一个姓名,一个学科,一个教课老师。所以这个公式会忽略学科这个维度,其余2个可以对其进行筛选。
忽略学科平均分:=Calculate(Average([成绩]),All('表1'[学科]))
- 如果要忽略多个维度,可以用多个列名来实现。
忽略学科教师平均分:=Calculate(Average([成绩]),All('表1'[学科],'表1'[教课老师]))
如果需要忽略的维度比不忽略的多,则可以使用AllExpect函数
2. AllExpect
A. 语法
ALLEXCEPT( <table>, <column> [, <column>[,…]])
位置 | 参数 | 描述 |
---|---|---|
第1参数 | table | 需要清除过滤器的表 |
第2参数 | column | 除外的列也就是需要保留筛选的列 |
可选第2重复参数 | column |
B. 返回
表——包含已经删除过滤器后的一列或多列的表。
C. 注意事项
- 第1参数是表,第2参数是列,而All函数的第1参数是表或者列。
- 直接在CALCULATE或CALCULATETABLE的过滤器参数中调用时,它不会实现结果表
- 通常和filter组合,如果是列名需要是filter处理的列名
D. 作用
忽略指定过滤器后进行计算。
之前这个使用All函数生成忽略学科教师平均分的度量值,如果用AllExpect函数则可以写成
忽略学科教师平均分:=Calculate(Average([成绩]),
All('表1'[学科],'表1'[教课老师]))
忽略学科教师平均分AllExpect:=Calculate(Average([成绩]),
AllExcept('表1','表1'[姓名]))