数据可视化之DAX篇(十七)Power BI表格总计行错误的终极解决方案
https://zhuanlan.zhihu.com/p/68183990
我在知识星球收到的问题中,关于表格和矩阵(以下统称表格)总计行错误算是常见的问题之一了,不少初学者甚为不解,在Excel透视表中很常见的总计,为什么到了更强大的 PowerBI 中,反而会出现这么低级的错误呢?
并且碰到这个错误,很多人都束手无策,不知道该怎么办,或者干脆设置为不显示总计行了,其实没有必要,本文就来介绍一下为什么会出现错误,以及解决的办法。
总计的计算逻辑
在PowerBI的表格中,每一个数据都是根据当前的上下文计算出来的,包括总计,也就是说,总计是按照总计行的上下文独立计算的,而不是根据上面的明细相加得来的。
为了理解上面这段话的含义,请看下面的例子。
假设要计算每个产品的订单数量,根据订单表中的数据,新建个度量值,
系统订单数量 = COUNTROWS('订单')
在矩阵中显示如下:

计算逻辑比较简单时,默认情况下总计行的数据是没问题的。
假设每种产品的订单中,都有两个是测试订单,也就是真实订单比系统中的订单数要少两个,那么真实订单的度量值如下:
实际订单数量 = COUNTROWS('订单')-2
把这个度量值放进来,看看是什么结果,

可以看到每一个产品的实际订单数量都少了两个,计算是正确的,但总计行竟然也只少了两个,明显与明细数据之和不符!
这就是总计的计算逻辑,它不管上面的明细数据是多少,它只是在汇总的订单数量的基础上减去2,于是得到了4624。
理解了这个计算逻辑,下面就来看看如何解决。
总计错误的解决方案
既然我们想让总计等于上面明细之和,那么我们就按照这个逻辑构建一个度量值,
------------------
实际订单数量1 =
IF(
HASONEVALUE('产品'[产品名称]),
[实际订单数量],
SUMX(
VALUES('产品'[产品名称]),
[实际订单数量]
)
)
-----------------
这个度量值的先利用IF函数做个判断,如果当前上下文是产品名称,就计算 [实际订单数量],否则,就利用SUMX对所有的产品名称的 [实际订单数量]求和。
看一下计算结果,
总计行得到了正确的结果。
实际上这个度量值的写法还可以继续简化,连IF判断都省略掉,直接用SUMX.
---------------
实际订单数量2 =
SUMX(
VALUES('产品'[产品名称]),
[实际订单数量]
)
---------------

同样得到了正确的结果。
这就是SUMX的强大之处,在明细行,利用VALUES函数获取当前的上下文,计算当前上下文的订单数量,在总计行,自动对筛选出的所有的产品名称的数据进行汇总。
[实际订单数量2]的写法,就是终极解决方案。
总结
为了使总计行计算出正确的结果,终极解决方案只需两步:
1、先正常写一个度量值,保证明细行正确;
2、在第1步度量值的基础上,套一层SUMX函数,即可保证明细行和总结行均正确。
然后使用第二步的度量值作为表格的值就可以了。
(如果熟练,你也可以一步写出最终的度量值)
记住这个终极方案DAX:
SUMX(
VALUES(明细行字段),
[明细行正确的度量值]
)
下次再遇到类似问题,你可以直接套用。
练习PowerBI时若没有数据,可以在公众号回复关键字"数据"获取我整理的近百个精选数据集。
如果文章对你有帮助,看完别忘了点个赞哦。
数据可视化之DAX篇(十七)Power BI表格总计行错误的终极解决方案的更多相关文章
- 数据可视化之DAX篇(二十七)半累加度量,在Power BI 中轻松处理
https://zhuanlan.zhihu.com/p/96823622 开始半累加的计算之前,我们先看看什么是累加.半累加以及不可累加数据. 在含有大量行的数据表中,各种数据处理语言,包括DAX ...
- 数据可视化之DAX篇(二)Power BI中的度量值和计算列,你搞清楚了吗?
https://zhuanlan.zhihu.com/p/75462046 对于初学者,总是会把度量值和计算列搞混,我也经常碰到这样的问题,有些星友用文章中的代码总是报错,发给我一看,才知道TA把本来 ...
- 数据可视化之DAX篇(十一)Power BI度量值不能作为坐标轴?这个解决思路送给你
https://zhuanlan.zhihu.com/p/79522456 对于PowerBI使用者而言,经常碰到的一个问题是,想把度量值放到坐标轴上,却发现无法实现.尤其是初学者,更是习惯性的想这么 ...
- 数据可视化之DAX篇(一)Power BI时间智能函数如何处理2月29日的?
https://zhuanlan.zhihu.com/p/109964336 今年是闰年,有星友问我,在Power BI中,2月29日的上年同期是怎么计算的? 这是个好问题,正好梳理一下,Power ...
- 数据可视化之DAX篇(二十八)Power BI时间序列分析用到的度量值,一次全给你
https://zhuanlan.zhihu.com/p/88528732 在各种经营分析报告中,我们常常会看到YTD,YOY这样的统计指标,这样的数据计算并不难,尤其是在PowerBI中,因为有时间 ...
- 数据可视化之DAX篇(二十四)Power BI应用技巧:在总计行实现条件格式
https://zhuanlan.zhihu.com/p/98975646 如何将表格或者矩阵中值的条件格式也应用于总计行? 目前PowerBI并不支持这种功能,无法在总计行或者小计行上应用条件格式, ...
- 数据可视化之DAX篇(二十一)连接表的几个DAX函数,一次全掌握
https://zhuanlan.zhihu.com/p/67015995 编写DAX代码进行业务分析时,经常会用到表与表之间的连接计算,比如在之前的产品关联分析一文中(如何用Power BI分析产品 ...
- 数据可视化之DAX篇(五) 使用PowerBI的这两个函数,灵活计算各种占比
https://zhuanlan.zhihu.com/p/57861350 计算个体占总体的比例是一个很常见的分析方式,它很简单,就是两个数字相除,但是当需要计算的维度.总体的范围发生动态变化时,如何 ...
- 数据可视化之DAX篇(十五)Power BI按表筛选的思路
https://zhuanlan.zhihu.com/p/121773967 数据分析就是筛选.分组.聚合的过程,关于筛选,可以按一个维度来筛选,也可以按多个维度筛选,还有种常见的方式是,利用几个特 ...
随机推荐
- Linux中GitLab的部署
1.版本控制介绍 版本控制最主要的功能就是追踪文件的变更.它将什么时候.什么人更改了文件的什么内容等信息忠实地了记录下来.每一次文件的改变,文件的版本号都将增加.除了记录版本变更外,版本控制的另一 ...
- flink实时数仓从入门到实战
第一章.flink实时数仓入门 一.依赖 <!--Licensed to the Apache Software Foundation (ASF) under oneor more contri ...
- c常用函数-atoi 和 itoa
atoi 和 itoa atoi的功能是把一个字符串转为整数 Action(){ int j; char *s=""; j = atoi(s); lr_output_message ...
- 多线程高并发编程(11) -- 非阻塞队列ConcurrentLinkedQueue源码分析
一.背景 要实现对队列的安全访问,有两种方式:阻塞算法和非阻塞算法.阻塞算法的实现是使用一把锁(出队和入队同一把锁ArrayBlockingQueue)和两把锁(出队和入队各一把锁LinkedBloc ...
- WeChair项目Beta冲刺(5/10)
团队项目进行情况 1.昨日进展 Beta冲刺第五天 昨日进展: 前后端并行开发,项目按照计划有条不絮进行 2.今日安排 前端:扫码占座功能和预约功能并行开发 后端:扫码占座后端逻辑开发,预约用座 ...
- v-forv-for指令的三种使用方法
1.迭代数组 <p v-for="(item,i) in list">id:{{item.id}}---名字:{{item.name}}---索引{{item.age} ...
- 「从零单排canal 03」 canal源码分析大纲
在前面两篇中,我们从基本概念理解了canal是一个什么项目,能应用于什么场景,然后通过一个demo体验,有了基本的体感和认识. 从这一篇开始,我们将从源码入手,深入学习canal的实现方式.了解can ...
- skywalking7 源码解析 (3) :agent启动服务分析以及性能影响
skywalking必看的文章,转载自https://blog.csdn.net/u010928589/article/details/106608864/
- WPF中的Data Binding调试指南
大家平时做WPF开发,相信用Visual studio的小伙伴比较多.XAML里面曾经在某些特殊版本的Visual Studio中是可以加断点进行调试的,不过目前多数版本都不支持在XAML加断点来调试 ...
- win10提示“无法设置移动热点 请打开WLAN”的解决方法
一位用户在使用Win10创意者操作系统过程中,遇到了无法开启移动热点的情况,开关呈灰色状态,而且提示:无法设置移动热点 请打开WLAN,该如何解决呢?该用户表示Wlan一直开着呀,感觉非常奇怪.接下来 ...