https://zhuanlan.zhihu.com/p/64150720

本文学习PowerBI最重要的概念:度量值


初学Power BI一般都会对度量值比较困惑,毕竟对长期接触Excel的人来说,这是个全新的概念,但一旦理解了她,肯定会立即喜欢上。

简单来说,度量值是用DAX公式创建一个虚拟字段的数据值,她不改变源数据,也不改变数据模型,如果你不在报表上使用她,甚至不知道她是什么样子的,而一旦被拖拽到报表上,便发挥巨大的作用,她可以随着切片器的筛选而闪转腾挪、变化万端,所以度量值一般在报表交互时使用。

说了这么多,你也许觉得更晕,不过没问题,这个概念不是靠语言能解释的很清楚的,在PowerBI报表上体验一下可能立即就明白了。

案例数据:

全国连锁电子产品专卖店的2016至2017年的销售明细,销售产品有三类:手机、电脑、平板,每一类又分别来自三个品牌:小米、苹果、三星,这个店销售的产品共计9个,全国8个城市门店设有门店。

还有几个维度表和一个日期表,模型关系图如下:

我们现在根据这个模型分析累计销售同比增长率。

先新建一个度量值[销售总额]:

销售总额 = sum('销售明细'[销售额])

然后在画布上添加矩阵表格可视化组件,把[月份]和刚创建的度量值分别放入行和值,每月的销售总额就出来了:

因为没有加入年度筛选,这时候的每月销售额实际上是2016和2017年的两个月份的合计额,所以现在加入一个年度切片器,

这个时候,选中年份,这个销售总额就是该年度当月的销售总额了。

因为我们是要分析本年累计销售金额的同比增长率,那么需要先得到本年累计销售金额和上年累计销售金额,新建两个度量值:

本年累计销售额 = TOTALYTD([销售总额],'日期表'[日期])
上年累计销售额 = TOTALYTD([销售总额],SAMEPERIODLASTYEAR('日期表'[日期]))

这里用了两个DAX函数,TOTALYTD函数是统计从年初到本月的金额,SAMEPERIODLASTYEAR返回的是上年同期的日期表,关于DAX函数先有个印象就行,后面会专门介绍。

把这两个度量值也放入矩阵中,选中2017年,本年和上年截至每个月份的累计销售额就出来了,

然后再添加个度量值[同比增长率],

累计同比增长率 = divide([本年累计销售额],[上年累计销售额])-1

把该度量值拖入矩阵,同比增长率就出来了,这就是利用这个数据模型实现的结果。

你也许觉得做个同比增长率也不是很麻烦,在Excel里面做也可以很快做出来,但是如果不只比较销售总额,还要分类别、分品牌来比较呢,是不是要在Excel里面做很多遍,况且这只是两年的数据,如果是20年呢,如果在100个城市设有门店呢,估计用传统Excel技能做要累吐血也做不完吧,而在刚才建立的模型里,无论有多少个维度,无论按哪个维度比较,都是点点鼠标的事:

这就是度量值的魅力,只是简单建立了四个度量值,然后就神奇的实现了多维度的比较,这要归功于度量值的最重要的特征:上下文。

上下文就是度量值所处的环境,筛选表的行列标签、切片器的选中,都是度量值的上下文,比如北京2017年截至5月的苹果手机累计销售额3424000,它的上下文就是下面这5个维度:

[城市]="北京市"
[品牌]="苹果"
[类别]="手机"
[年度]=2017
[月份]=5月

理解了上下文,就理解了度量值的最重要的特征,因此她被称为移动的公式,随着上下文环境的不同而展示不同的数据,度量值另外还有两个主要特征:

度量值不浪费内存,只有被拖到图表上才执行运算,如果数据量非常大的时候这点非常有利

  • 度量值可以循环使用,比如上面的建立的度量值:
    本年累计销售额 = TOTALYTD([销售总额],'日期表'[日期])
    累计同比增长率 = divide([本年累计销售额],[上年累计销售额])-1,
    就是直接调用之前建立好的度量值,所以以后在模型中新建度量值的时候,推荐从最简单的度量值开始建。

看到这里是不是对度量值的认识比较清晰了,如果动手做一遍会更加理解上下文。建立合理的数据模型,加上灵活运用度量值,以后无论遇到什么数据分析都不是难题了。

度量值的创建离不开函数,这里用到的函数称为DAX,后面会主要介绍,并通过DAX实例来加深对度量值的理解。

案例数据可在公众号回复“度量值案例数据”下载。

数据可视化之powerBI入门(十)认识Power BI的核心概念:度量值的更多相关文章

  1. 数据可视化之powerBI入门 (一)认识PowerBI

    来自  https://zhuanlan.zhihu.com/p/64144024 Power BI是什么? Power BI是微软推出的数据分析和可视化工具,我们先来看看微软官方是怎么介绍的: Po ...

  2. 数据可视化之powerBI入门(四)Power BI与PowerQuery、PowerPivot有什么关系

    https://zhuanlan.zhihu.com/p/64146209 Power BI与PowerQuery.PowerPivot有什么关系? 刚开始学习PowerBI的时候,总是能碰到Powe ...

  3. 数据可视化之powerBI入门(十一)认识Power BI数据分析语言DAX

    DAX是英文Data Analysis Expression的缩写,意思是数据分析表达式,从名称上就可以看出,DAX公式是用作数据分析的,事实上也确实如此,从数据分析层面认识DAX会更有助于我们理解它 ...

  4. 数据可视化之powerBI入门(十二)PowerBI中最重要的函数:CALCULATE

    https://zhuanlan.zhihu.com/p/64382849 介绍DAX的时候,特别强调过一个重要的函数:CALCULATE,本文就来揭秘这个函数的计算原理以及它是如何影响上下文的. C ...

  5. 数据可视化之powerBI入门(二)体验PowerBI:零基础分分钟生成一份交互报表

    https://zhuanlan.zhihu.com/p/64144595 体验PowerBI:零基础分分钟生成一份交互报表 首先我们准备一份数据,Excel格式 数据是从2006年到2015年10年 ...

  6. 数据可视化之powerBI入门(三)财务人员必学,使用Powerquery是一种什么体验?

    https://zhuanlan.zhihu.com/p/54700574 财务人员必学,使用Powerquery是一种什么体验? 你和Excel高手的距离只差了一个Power Query!!! 先思 ...

  7. 数据可视化之powerBI入门(九)PowerBI数据建模:其实一点都不高深

    https://zhuanlan.zhihu.com/p/64149834 数据建模并没有那么高深,你同样可以学会!这篇文章通过一个实例创建一个简单的数据建模,并引出两个重要的概念:度量值和DAX. ...

  8. 数据可视化之powerBI入门(七)数据清洗中最常使用的十三招

    https://mp.weixin.qq.com/s?__biz=MzA4MzQwMjY4MA==&mid=2484067158&idx=1&sn=4ad955112df2f4 ...

  9. 数据可视化之powerBI入门(十三)CALCULATE函数的最佳搭档:FILTER

    https://zhuanlan.zhihu.com/p/64383000 介绍过CALCULATE函数之后,有必要再介绍它的最佳搭档:FILTER函数. CALCULATE函数的第二个及之后的参数是 ...

随机推荐

  1. Cypress系列(22)- 可操作类型的命令 之 select()

    如果想从头学起Cypress,可以看下面的系列文章哦 https://www.cnblogs.com/poloyy/category/1768839.html .select() 在 <sele ...

  2. EIGRP-10-弥散更新算法-计算距离,报告距离,可行距离和可行性条件

    对于某个目的网络,EIGRP持续关注它的各种距离参数.EIGRP使用复合度量参数,不过为了简化,这里使用一个没有单位的数值.同样出于简化,这里的EIGRP路由器都不使用水平分割.

  3. 关键时刻,让你的iphone拒绝掉的所有来电

    夜间被骚扰电话吵醒是会非常烦躁的,以下就是iphone的勿扰模式,配合刚出的夜间深夜模式非常的nice. 可以自定义设置时间段,每天智能切换. 也可以开启个人收藏的白名单,让家人有紧急事情也可以联系到 ...

  4. 分享2个近期遇到的MySQL数据库的BUG案例

    近一个月处理历史数据问题时,居然连续遇到了2个MySQL BUG,分享给大家一下,也欢迎指正是否有问题. BUG1: 数据库版本:  MySQL5.7.25 - 28 操作系统: Centos 7.7 ...

  5. RocketMQ启动

    下载RocketMQ解压启动 > unzip rocketmq-all-4.4.0-source-release.zip > cd rocketmq-all-4.4.0/ > mvn ...

  6. vue学习第二天:Vue跑马灯效果制作

    分析: 1. 给开始按钮绑定一个点击事件 2.在按钮的事件处理函数中,写相关的业务代码 3.拿到msg字符串 4.调用字符串的substring来进行字符串的截取操作 5.重新赋值利用vm实例的特性来 ...

  7. java web20套项目

    http://shenghuo.lshou.com/c4154/t5bdbcc98b9a9.html

  8. openstack迁移计算节点所有云主机

    迁移计算节点所有云主机 -------高德置地 王锦雄   使用host-evacuate-live热迁移主机 查看主机目前的云主机情况 nova hypervisor-servers cloud1 ...

  9. Java常见23中设计模式之【代理模式】

    一.静态代理模式 静态代理,使用继承的方式实现自己新增的服务 这种模式可以实现帮助被代理者完成一些前期的准备工作和后期的善后工作,但是核心的业务逻辑仍然是由被代理者完成. 在某些情况下,一个客户不想或 ...

  10. 从发布-订阅模式谈谈 Flask 的 Signals

    发布-订阅模式 发布-订阅模式,顾名思义,就像大家订报纸一样,出版社发布不同类型的报纸杂志不同的读者根据不同的需求预定符合自己口味的的报纸杂志,付费之后由邮局安排人员统一派送. 上面一段话,提到了发布 ...