5个适用于初学者的有用数据分析表达式(DAX)函数

数据分析表达式(DAX)入门可能令人生畏,但是,当你了解一些基本功能后,就可以帮助你解答许多有关数据的新见解。虽然在Power BI或Pivot Charts中创建视觉效果很容易,但我们经常希望查看特定时间范围的数据,或者应用或删除特定过滤器的数据,而这些数据是我们无法使用原始数据完成的。

如果你遇到过这个问题,那么掌握DAX的一些基本知识可以让你在模型中创建数据视图更便捷。作为Power BI和DAX的相对新手,我建议先学会这5个基本的DAX函数。

   报告视图

   关系视图

1.  FILTER

FILTER函数用于返回表或表达式的子集,如下所示。

FILTER(<table>,<filter>)

假设你想获得大于100美元的商品。我们可以使用COUNTROWS函数来计算指定表中的行数,以及FILTER函数来完成此过滤:

统计订单销售大于100 = COUNTROWS(FILTER(‘Sales‘, ‘Sales‘ [Sales] > 100))

  • 第一个参数‘Sales‘标识一个表或一个表格。
  • 第二个参数‘Sales‘[Sales]> 100,表示为表的每一行计算的布尔值或true / false表达式。
  • 在此表达式中,我们将Sales表传递给FILTER函数,并要求它返回任何大于100美元的商品。FILTER函数从不用作独立函数,但与其他函数一起使用。在上面的示例中,我们使用FILTER函数返回子集,然后计算结果。

2.  ALL

ALL函数用于返回表中的所有行或列中的值,忽略可能已应用的任何过滤器。

ALL(<table>或<column>)

  • 在上面的报告视图中,我们的报告包含多个卡片和一个不包含德国销售额的页面级过滤器。
  • 我们希望保留此过滤器,但添加一个可视化的卡片,显示已售出的商品总数,忽略放置在报告其余部分的任何过滤器。
  • 以下包含ALL函数的表达式可以帮助你实现此目的:

统计订单数 = COUNTROWS(ALL(‘Sales‘))

在这个例子中,我们将‘Sales‘表传递给ALL函数,要求它清除可能放在它上面的任何过滤器。与FILTER函数一样,ALL函数不是独立使用,而是与其他函数一起使用。

在这种情况下,我们将ALL函数与COUNTROWS函数结合使用,以获取所有销售记录的计数。ALL函数接受表或列,并清除可能已放置在它们上的任何过滤器。

3.  RELATED 

RELATED函数从另一个表返回一个相关值(如下所示)。

RELATED(<column>)

  • 到目前为止,我们已经使用了可以帮助你返回子集或清除表或列上的任何过滤器的函数。
  • 我们现在想要仅针对美国过滤我们的销售,但是在一个表中没有我们需要的所有数据来完成此操作。幸运的是,我们有RELATED函数,我们可以通过已建立的关系将值从一个表检索到另一个表。
  • 鉴于Sales表和SalesGeography表之间存在多对一关系,我们可以使用包含RELATED函数的以下表达式来返回仅美国的销售订单计数:

统计美国的订单 = COUNTROWS(FILTER(ALL(‘Sales‘), RELATED(‘SalesGeography‘[Countries]) = "美国"))

4.  TOTALYTD / TOTALQTD / TOTALMTD

DAX中的时间智能功能使你能够使用时间段(包括天,月,季度和年)来操纵数据,然后构建和比较这些时段的计算。

TOTALYTD(<expression>,<dates>[,<filter>][,<year_end_date>])

继续上面的例子,假设你希望看到今年迄今为止的总销售额。以下包含TOTALYTD函数的表达式可以让你轻松执行此操作:

今年的销售订单 = TOTALYTD(SUM(‘Sales‘[Sales]), ‘Dates‘[Dates])

  • 第一个参数‘Sales‘[Sales]标识要聚合的列。这也可以是返回标量或奇异值的表达式。
  • 第二个参数“日期”[日期]是包含日期的列。时间智能功能是非常有用的功能,消除了在常用时间段内计算聚合的复杂代码的需要。

5.  CALCULATE 

CALCULATE函数计算由特定过滤器修改的上下文中的表达式。

CALCULATE(<expression>,<filter1>,<filter2> ...)

假设你现在有兴趣列出所有区域的所有销售情况。虽然你可以创建一些零碎的表达式来实现这一点,但你可以使用CALCULATE函数轻松而干净地完成相同的操作。

以下示例使用CALCULATE函数,可以完成此任务:

所有国家除以地区的销售总额 = CALCULATE(SUM(‘Sales‘[Sales]),ALL(‘SalesGeography‘))

  • 第一个参数SUM(‘Sales‘[Sales])标识要聚合的列。
  • 第二个参数ALL(‘SalesGeography‘)表示一个布尔值,用于删除可能已放置在SalesGeography表上的所有过滤器。
  • 请注意,这会忽略排除德国销售的页面级过滤器。CALCULATE函数是DAX中功能最强大,最有用的函数之一。将CALCULATE函数视为增压“IF”语句是有帮助的。一些规则适用于CALCULATE函数:过滤器参数不能引用度量,并且表达式不能使用任何扫描或返回表的函数。CALCULATE函数通常与聚合函数一起使用,尽管过滤器参数是可选的,但通常至少使用一个。

在DAX中创建一些非常复杂的查询经常出现的,但只是精通几个函数可以帮助你了解许多有趣的数据洞察。我建议查看Microsoft的DAX参考以获取更多信息。

Make senses to you?

延伸阅读:

揭秘“DAX切片器”神秘的面纱

如何巧妙制作“形状地图”

一劳永逸的网页数据采集神技能,你get到了吗?

Power BI Desktop中处理Top的两种方法

Power BI数据存储管理

Power BI动态Top N 切片器 偏方拿好

Power BI 必备技能 -动态 “指标切换”

Power BI 必备技能 ― "书签"应用

解读Power BI数据安全性

抢鲜 | Power BI绽放的黑科技离我们还有多远?



长按下方二维码关注“悦策Power BI”获取更多微软Power BI干货及培课程学习,同时也欢迎各位小伙伴们转发分享哟~ ~

原文地址:https://www.cnblogs.com/yeacer/p/9300869.html

时间: 2024-10-12 21:58:25

5个适用于初学者的有用数据分析表达式(DAX)函数的相关文章

对Verilog 初学者比较有用的整理(转自它处)

对Verilog 初学者比较有用的整理(转自它处) ******************************************************************************************************************** *作者: Ian11122840    时间: 2010-9-27 09:04                                                                   

【C++】C++中的lambda表达式和函数对象

目录结构: contents structure [-] lambda表达式 lambda c++14新特性 lambda捕捉表达式 泛型lambda表达式 函数对象 函数适配器 绑定器(binder) std::mem_fn()适配器 lambda表达式是C++11中引入的一项新技术,利用lambda表达式可以编写内嵌的匿名函数,用以替换独立函数或者函数对象,并且使代码更可读.但是从本质上来讲,lambda表达式只是一种语法糖,因为所有其能完成的工作都可以用其它稍微复杂的代码来实现.但是它简便

[转]javascript函数定义表达式和函数声明的区别

在javascript中,函数有两种定义写法,函数定义表达式和函数声明,其例子分别如下所示: var test = function(x){ return x; } function test(x){ return x; } 尽管函数定义表达式和函数声明语句包含相同的函数名,并且都创建了新的函数对象,但是这二者却有区别. 函数声明语句中的函数名是一个变量名,变量指向函数对象. 函数定义表达式和通过var声明变量一样,其函数被提前到了脚本或函数的顶部,因此它在整个脚本和或函数内都是可见的.这样的话

变量声明置顶规则、函数声明及函数表达式和函数的arguments属性初始化

一.变量声明和变量赋值: if (!("a" in window)) { var a = 1; } alert(a);//a为? 你可能认为alert出来的结果是1,然后实际结果是"undefined".要了解为什么,我们需要知道JavaScript里的3个概念: 1.所有的全局变量都是window的属性,语句 var a = 1;等价于window.a = 1; 可以用如下方式来检测全局变量是否声明: "变量名称" in window 2.声明

js函数表达式和函数声明的区别

我们已经知道,在任意代码片段外部添加包装函数,可以将内部的变量和函数定义"隐 藏"起来,外部作用域无法访问包装函数内部的任何内容. 例如: var a = 2; function foo() { // <-- 添加这一行 var a = 3; console.log( a ); // 3 } // <-- 以及这一行 foo(); // <-- 以及这一行 console.log( a ); // 2 虽然这种技术可以解决一些问题,但是它并不理想,因为会导致一些额外的

函数表达式和函数声明~(自己的记录)

在ECMAScript中,创建函数的最常用的两个方法是函数表达式和函数声明,两者期间的区别是有点晕,ECMA的规范明确了一点~函数声明必须带有标示符 (Identifier)就是大家说的(函数名),而函数表达式则可以省略函数名. 那么没有函数名那肯定就是函数表达式了,那么有函数名时,如何区分它是函数表达式还是函数声明呢~~如果是作为赋值表达式的一部分则为函数表达式,如果是包含在一个函数体内,或者位于程序的最顶部的话则作为函数声明~ function foo(){} // 声明,因为它是程序的一部

8个很有用的PHP安全函数,你知道几个?

原文:Useful functions to provide secure PHP application 译文:有用的PHP安全函数 译者:dwqs 安 全是编程非常重要的一个方面.在任何一种编程语言中,都提供了许多的函数或者模块来确保程序的安全性.在现代网站应用中,经常要获取来自世界各地用户的输 入,但是,我们都知道“永远不能相信那些用户输入的数据”.所以在各种的Web开发语言中,都会提供保证用户输入数据安全的函数.今天,我们就来看看,在 著名的开源语言PHP中有哪些有用的安全函数. 在PH

JS中函数表达式与函数声明的区别

hello,沐晴又来更新啦,今天呢,跟大家讲讲让人头疼的函数表达式和函数声明,反正我当初看那本高级程序的时候,是没怎么看太透,哈哈.我是个比较重基础的人,跟我一起探讨函数表达式和函数声明的世界吧. 首先呢,先看看他们的颜值:   函数声明:function 函数名(){}   函数表达式:function 函数名(可写可不写)(){}; (不写名叫做匿名函数表达式.写名叫做命名函数表达式.推荐用匿名的.) 这么一看长的好像没啥区别,反正颜值也都不高.那么我们如何区别是函数表达式还是函数声明呢?答

javascript 用函数语句和表达式定义函数的区别详解

通常我们会看到以下两种定义函数的方式: // 函数语句 function fn(str) { console.log(str); }; // 表达式定义 var fnx=function(str) { console.log(str+ ' from fnx'); }; 两种方式都创建了新的函数对象, 但函数声明语句的函数名是一个变量名, 变量指向函数对象, 和通过var声明变量一样,函数定义语句中的函数被显示地提前到了脚本或函数的顶部, 因此它们在整个脚本和函数内都是可见的,但是使用var 表达