“不理解上下文,就无法真正掌握DAX;理解了上下文,就掌握了Power Pivot的精髓。”——心至无悔
一、上下文:Power Pivot的计算基石
在Power Pivot中,上下文是决定公式计算结果的环境和规则。它就像是DAX语言的"语法规则",只有深入理解上下文,才能编写出正确且高效的数据分析公式。
1.1 为什么上下文如此重要?
- 上下文决定了公式中引用的数据范围
- 相同的DAX公式在不同上下文中会产生不同结果
- 理解上下文是调试和优化DAX公式的关键
- 上下文机制是Power Pivot区别于传统Excel的核心特征
二、两种核心上下文类型
2.1 行上下文(Row Context)
定义:行上下文代表"当前正在处理的行",它存在于逐行计算的环境中。
产生场景:
- 在计算列中自动创建
- 在使用迭代函数时创建(SUMX、FILTER、MAXX等)
-- 计算列中的行上下文
利润 = Sales[销售额] - Sales[成本] -- 对每一行独立计算
-- 迭代函数中的行上下文
总利润 = SUMX(Sales, Sales[销售额] - Sales[成本]) -- 逐行计算后求和
关键特性:
- ✅ 自动在计算列和迭代函数中创建
- ✅ 可以读取当前行的字段值
- ❌ 不会自动传递给相关表(需要使用RELATED)
- ❌ 不会自动转换为筛选上下文
2.2 筛选上下文(Filter Context)
定义:筛选上下文定义了哪些数据应该被包含在计算中,它由各种筛选操作创建。
产生场景:
- 数据透视表的行/列标签
- 切片器选择
- CALCULATE函数中的筛选参数
- 报表级别的筛选器
-- 筛选上下文示例
华东销售额 = CALCULATE(SUM(Sales[销售额]), Region[区域] = "华东")
关键特性:
- ✅ 可以沿着模型关系自动传递
- ✅ 决定聚合函数的计算结果
- ✅ 可以被CALCULATE函数修改
- ✅ 度量值始终在筛选上下文中计算</

最低0.47元/天 解锁文章
2214

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



