数据可视化之DAX篇(三) 认识DAX中的表函数和值函数
https://zhuanlan.zhihu.com/p/64421003
学习 DAX 的过程中,会遇到各种坑,刚开始甚至无法写出一个正确的度量值,总是提示错误。其实很多原因都是不理解 DAX 函数及其参数规范造成的,在该用表的时候没有用表,该用列的时候没有用列。
常见的 DAX 函数返回一个值,比如 SUM、MAX 等,称为值函数,这些和 Excel 公式有很多相似之处,很容易理解;难以理解的是和Excel公式不同的地方:DAX 中还有很多表函数。
表函数就是返回的是一张表,如果我们用这种函数建立度量值或者新建列时,很可能会报错,比如很常见的函数 FILTER,可以作为值函数的参数存在,它无法独立建立度量值,因为FILTER函数返回的就是一张表,可以在 PowerBI 中测试一下,点击新表,输入,
= FILTER('订单','订单'[产品名称]="U盘")

返回的是所有U盘的销售订单表。
用这个表达式无法建立度量值,只有再把这个表进行聚合才可以,比如在刚才的表达式外面再套一个 COUNTROWS,计算该表的行数,就可用于度量值,这个度量值的含义是统计U盘的订单数量。
在 PowerBI 中使用 DAX 的是这三个地方,新建度量值、新建列和新表,

其中前两个都是需要返回的是一个值,如果用返回表的表达式来创建,将会出现错误提示,而新表是利用DAX创建一个表,它使用的就是返回表的表达式。
哪些函数返回值,哪些函数返回表
常见的值函数就是聚合函数,比如常用到的 SUM、COUNTROWS、AVERAGE,以及CALCULATE、SUMX等;
表函数也经常用到,除了上面看到的 FILTER,ALL 也是个表函数,前面的文章中使用过的还有 VALUES、DISTINCT、UNION、ADDCOLUMNS、SELECTCOLUMNS 等;
哪些函数的参数是列,哪些函数的参数是表
值函数返回的虽然是一个值,但其参数可能需要一张表,比如 SUMX,它的第一个参数就是一张表。
表函数返回的是表,但是参数也有可能需要的是列,比如 VALUES,它的参数是一列,返回的该列的不重复值,只有一列的表。
有些表函数的参数,既可以是值、也可以是表,比如 ALL 函数,正如前面看到的,既可以写 ALL('产品表'),也可以写成 ALL('产品表'[产品名称]),只是代表的意义是不同的。
如果某函数的参数是列,我们只能把某个表的列作为参数,而不能是整个表。如果参数是表,而我们要处理的列,怎么办?其中一种方式就是用VALUES 把列转化为表,然后作为参数。
另外 VALUES 函数虽然返回的是表,不过它返回的是只有一列的表,如果这个表仅有一行,那么它同时也是值,在 DAX 中,只有一行一列的表,就是个值,所以 VALUES 在某些情况下也可以用于度量值的创建,在使用DAX时会经常用到这个特性。
通过上面的介绍,基本就知道了很多 DAX 函数报错的原因,使用DAX函数时,一定要做到心中有数,该用表的时候用表,该用值的时候用值,那么如何掌握这些呢,这里推荐学习DAX的最佳网站:https://dax.guide
DAX GUIDE

这是 DAX 世界级大神9月份刚推出的一个简洁实用的学习网站,收录了所有的DAX函数,如果有新的 DAX 发布,它也会同步更新。
左侧是 DAX 函数的列表,点击就可以看到该函数的含义及各种使用特性,比如ALL函数,

上图中只是标记了参数的类型和返回的类型,实际上该网站的其他标记也非常重要,有的甚至还列出了使用方式和示例,特别有助于理解使用。
当然你也看到了,这是个全英文的网站,如果英文水平不是太好,推荐用Chrome 浏览器,可以直接翻译网页。
数据可视化之DAX篇(三) 认识DAX中的表函数和值函数的更多相关文章
- 数据可视化之PowerQuery篇(四)二维表转一维表,看这篇文章就够了
https://zhuanlan.zhihu.com/p/69187094 数据分析的源数据应该是规范的,而规范的其中一个标准就是数据源应该是一维表,它会让之后的数据分析工作变得简单高效. 在之前的文 ...
- 数据可视化之DAX篇(二十一)连接表的几个DAX函数,一次全掌握
https://zhuanlan.zhihu.com/p/67015995 编写DAX代码进行业务分析时,经常会用到表与表之间的连接计算,比如在之前的产品关联分析一文中(如何用Power BI分析产品 ...
- 数据可视化之PowerQuery篇(十九)PowerBI数据分析实践第三弹 | 趋势分析法
https://zhuanlan.zhihu.com/p/133484654 本文为星球嘉宾"海艳"的PowerBI数据分析工作实践系列分享之三,她深入浅出的介绍了PowerBI ...
- 数据可视化之分析篇(九)PowerBI数据分析实践第三弹 | 趋势分析法
https://zhuanlan.zhihu.com/p/133484654 以财务报表分析为例,介绍通用的分析方法论,整体架构如下图所示: (点击查看大图) 我会围绕这五种不同的方法论,逐步阐述他们 ...
- 数据可视化之PowerQuery篇(三)学会使用PowrQuery的自定义函数
https://zhuanlan.zhihu.com/p/64415763 使用Power Query进行复杂一些的数据处理,离不开M函数,目前已经有超过700个函数了,基本上各式各样的数据处理需求都 ...
- 数据可视化之分析篇(八)Power BI数据分析应用:结构百分比分析法
https://zhuanlan.zhihu.com/p/113113765 PowerBI数据分析02:结构百分比分析法 作者:海艳 结构百分比分析法,又称纵向分析,是指同一期间财务报表中不同项目间 ...
- 数据可视化之PowerQuery篇(十八)Power BI数据分析应用:结构百分比分析法
https://zhuanlan.zhihu.com/p/113113765 本文为星球嘉宾"海艳"的PowerBI数据分析工作实践系列分享之二,她深入浅出的介绍了PowerBI ...
- 数据可视化之 图表篇(二)如何用Power BI制作疫情地图?
丁香园制作的这个地图可视化,相信大家每天都会看好几遍,这里不讨论具体数据,仅来探讨一下PowerBI地图技术. 这个地图很简洁,主要有三个特征: 1,使用着色地图,根据数据自动配色 2,只显示中国地图 ...
- 数据可视化之分析篇(一)使用Power BI进行动态帕累托分析
https://zhuanlan.zhihu.com/p/57763423 通过简单的点击交互,就能进行动态分析发现见解,才是我们需要的,恰好这也是 PowerBI 所擅长的. 就帕累托分析来说,能从 ...
随机推荐
- 在SpringMVC获取客户端传递的数据的方式
在处理请求的方法中,加入相对应的形参,保证形参参数名和传递的数据的参数名保持一致,就能够自动赋值 value:当不满足赋值条件时,可以使用value属性,指定映射关系 required:设置形参是否必 ...
- Chosen by god【组合数打表】
Chosen by god 题目链接(点击) Everyone knows there is a computer game names "hearth stone", recen ...
- eval5: TypeScript编写的JavaScript解释器
eval5是基于TypeScript编写的JavaScript解释器,100%支持ES5语法. 项目地址:https://github.com/bplok20010/eval5 使用场景 浏览器环境中 ...
- 面试官:线程池如何按照core、max、queue的执行循序去执行?(内附详细解析)
前言 这是一个真实的面试题. 前几天一个朋友在群里分享了他刚刚面试候选者时问的问题:"线程池如何按照core.max.queue的执行循序去执行?". 我们都知道线程池中代码执行顺 ...
- mitmdump+python的使用(代码篇)
mitmproxy+python代码篇 一.上个推文我们介绍了mitmdump的简单操作,下面我们开始学习,mitmdump配合python脚本的使用.第一点先讲日志输出.请看图片 先导入ctx模块: ...
- Arduino连接LCD1602显示屏
简介 LCD1602是一种工业字符型液晶,能够同时显示16x02即32个字符.LCD1602液晶显示的原理是利用液晶的物理特性,通过电压对其显示区域进行控制,即可以显示出图形.[百度百科] 引脚说明 ...
- 09.DRF-ModelSerializer
四.模型类序列化器ModelSerializer 如果我们想要使用序列化器对应的是Django的模型类,DRF为我们提供了ModelSerializer模型类序列化器来帮助我们快速创建一个Serial ...
- Windows 安装RabbitMQ后,启动服务就自动停止
在做SpringCloud消息总线的时候,需要用到RabbitMQ,于是在windows上下载安装了一个,erlang的安装包不是官网下载的,而是朋友分享给我的,没注意它的版本(9.3). 安装完成后 ...
- Java | 顶层类(Top-Level Class)
前言 本文内容根据 Java 官方教程中的<课程:类和对象>编写而成. 本文提供的是 JDK 14 的示例代码. 定义 顶层类(Top-Level Class),是 Java 中对类的一种 ...
- Sql sever 声明变量,赋值变量
语句: --声明变量DECLARE @idcard nvarchar () , @rowid nvarchar () --给变量赋值SELECT @idcard = '{0}', @rowid = ' ...