【Power BI】DAX语言 VS Power Query M语言

在这里插入图片描述

DAX(Data Analysis Expressions)和Power Query M语言是Microsoft Power BI和Excel中的两种强大的数据处理和分析工具。尽管它们在许多方面都有重叠之处,特别是用于数据建模和数据转换,但它们在用途、语法和功能上有显著的区别。本文将详细探讨DAX和Power Query M语言的区别。

一、定义与用途

DAX

  • DAX(Data Analysis Expressions,数据分析表达式),是一个由函数和运算符构成的库,用于数据分析和计算。
  • DAX 公式包括函数、运算符和值,用于对表格数据模型中相关表和列中的数据执行高级计算和查询。这些函数和运算服务可进行组合,在 Excel 数据模型中的 Power BI、Analysis Services 和 Power Pivot 内生成公式和表达式。

Power Query M语言

  • Power Query M语言是一种数据查询语言,用于数据提取、转换和加载(ETL)。
  • Power Query 的核心功能是筛选和合并,即从支持的数据源的一个或多个丰富集合中混合数据。 任何此类数据混合将使用 Power Query M 公式语言来表示。 M语言在Power BI、Excel和其他Microsoft数据处理工具中用于数据的预处理和转换。它允许用户从各种数据源提取数据,并对其进行清洗和整理。

二、语法与表达方式

DAX

  • DAX的语法与Excel公式类似,但更为复杂和强大。它使用函数、运算符和特定的语法结构来进行数据操作。例如:
    Total Sales = SUM(Sales[SalesAmount])
    

Power Query M语言

  • M语言的语法类似于函数式编程语言,使用let表达式和查询步骤来定义数据转换流程。

  • M语言通过一系列的步骤来逐步转换数据,这些步骤通常用在Power Query编辑器中。例如,加载一个Excel文件并筛选数据:

    let
        Source = Excel.Workbook(File.Contents("C:\Data\SalesData.xlsx"), null, true),
        SalesData = Source{[Name="SalesData"]}[Data],
        FilteredRows = Table.SelectRows(SalesData, each [SalesAmount] > 1000)
    in
        FilteredRows
    

三、使用场景

DAX

  • 主要场景:用于数据模型中的计算和分析。例如,在Power BI报表中创建动态指标和自定义聚合。
  • 常见应用:几乎是Power BI中一定会使用到的,比如创建度量值(Measures)、计算列(Calculated Columns)、时间智能函数(Time Intelligence)、聚合计算等。
  • ![[DAX  VS Power Query M-20240514154214820.webp]]

Power Query M语言

  • 主要场景:用于数据加载和预处理。例如,从不同的数据源提取数据并进行清洗和整合,确保数据在加载到模型之前已经过处理和准备。
  • 常见应用:数据提取(ETL)、数据清洗、数据合并、数据转换等。大部分功能可以直接通过工具栏操作实现,基本不需要手写M语言。
  • ![[DAX  VS Power Query M-20240514154523450.webp]]

总的来说,DAX和Power Query M语言在Power BI和Excel中的角色是互补的。DAX主要用于数据建模中的计算和分析,而M语言则用于数据预处理和转换。理解这两者的区别和各自的优势,可以帮助用户更有效地处理和分析数据,从而在数据驱动的决策中获得更好的成果。

在实际应用中,对于Power BI而言,DAX是不可避免的学习部分,M语言大部分功能已经由工具栏按键替代,除非特殊复杂的操作,一般可以略过查看M语言代码;而在Excel中,普通的操作基本不会用到这两种语言,如果有使用的需求,也不能完全照搬Power BI的方法,在不同的环境中,哪怕是实现同样的功能,DAX 和M 语言还是可能会有细微差别。

数据分析表达式 (DAX) 引用 - DAX | Microsoft Learn
Power Query M 公式语言引用 - PowerQuery M | Microsoft Learn

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/624678.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

干部民主测评:深化管理智慧,凝聚团队力量

在现代化组织管理的广阔舞台上,干部民主测评扮演着举足轻重的角色。它不仅是评价干部工作实绩、能力素质的有力工具,更是推动组织向民主化、科学化、规范化迈进的强大引擎。通过民主测评,我们能够深入洞察每位干部的工作表现、群众基础和领导…

QT的创建,发现编译器有一个黄色三角形感叹号,提示说Cmake配置错误,该怎么办?

确保你安装了Cmake 2.如果你电脑之前已经装了Cmake,那么在qt安装中,即便你选择了Cmake版本,但依旧不会修改电脑的Cmake版本。这时候就会出现黄色箭头。在勾勾的地方会有一个黄色感叹符号(我已经解决了,所以没有显示&a…

火遍全网的“当当狸智能激光雕刻机L1” 让创意梦想分分钟实现

当当狸首款“桌面级”智能激光雕刻机来袭,千万别错过。 龙年伊始,当当狸就迎来了新品首发——智能激光雕刻机L1。 话不多说,赶快来看~~ 当当狸这款智能激光雕刻机造型美观,设计时尚,堪称激光雕刻机界的颜值天花板~~ …

【八大排序算法】插入排序、希尔排序、选择排序、堆排序、冒泡排序、快速排序、归并排序、计数排序

文章目录 一、排序的相关概念二、排序类型三、排序算法实现插入排序1.直接插入排序2.希尔排序 选择排序3.简单选择排序4.堆排序 交换排序5.冒泡排序6.快速排序递归实现非递归实现 7.归并排序递归实现非递归实现 8.计数排序 四、总结 一、排序的相关概念 排序:根据数…

独立服务器和云服务器哪个好?

在当今数字时代,网站托管是任何在线业务成功的关键要素之一。但是,当谈到选择正确的托管解决方案时,很容易陷入独立服务器与云服务器之间的抉择。两者都有各自的优势和限制,因此在决定哪种类型的托管适合您的业务之前,…

Samtec技术分享 | 电源/信号高密度阵列的新视角

【摘要/前言】 “角度”,这个词每天都出现在我们的生活中,有物理学的角度,如街边的拐角,还有视觉上的角度和观点中的角度~ Samtec新型 AcceleRate mP 高密度电源/信号互连系统正是从电源完整性 90度旋转的不同角度中诞生的。 …

基于Java+SpringBoot+vue+elementui 实现猜灯谜答题抽奖系统

目录 系统简介效果图1、手机答题端2、后台系统管理 源码结构源码下载地址技术交流 博主介绍: 计算机科班人,全栈工程师,掌握C、C#、Java、Python、Android等主流编程语言,同时也熟练掌握mysql、oracle、sqlserver等主流数据库&…

通过cmakelist生成与调用C++动态链接库

文章目录 前言生成动态链接库样例项目说明修改cmakelist 调用动态链接库修改配置文件修改原来外层的CMakeLists.txt 总结 前言 此前有写过用编译工具链直接通过命令行的方式生成与调用C动态链接库的方法,本文记录下通过cmake来实现so的生成。 生成动态链接库 样例…

C++指针和动态内存分配细节,反汇编,面试题05

文章目录 20. 指针 vs 引用21. new vs malloc 20. 指针 vs 引用 指针是实体,占用内存空间,逻辑上独立;引用是别名,与变量共享内存空间,逻辑上不独立。指针定义时可以不初始化;引用定义时必须初始化。指针的…

Java 对象序列化

序列化:把对象转化为可传输的字节序列过程称为序列化。 反序列化:把字节序列还原为对象的过程称为反序列化 序列化的作用是方便存储和传输,细节可参考如下文章: 序列化理解起来很简单 - 知乎序列化的定义 序列化:把对…

代码随想录训练营Day38、39:Leetcode509、70、746、62、63

Leetcode509: 问题描述: 斐波那契数 (通常用 F(n) 表示)形成的序列称为 斐波那契数列 。该数列由 0 和 1 开始,后面的每一项数字都是前面两项数字的和。也就是: F(0) 0,F(1) 1 F(n) F(n -…

什么是MVC?什么是SpringMVC?什么是三层架构?

文章目录 应用分层什么是MVC?什么是 SpringMVC?三层架构三层架构和MVC的关系 应用分层 在讲解什么是MVC之前,先来理解一下什么是应用分层。 应用分层是一种软件开发设计思想,将应用程序划分成N个层次,每个层次都分别负责自己的…

本地安装nvm,管理多版本node

先卸载本地的nodejs(14.16.1) 卸载的直接可以点击win10图标→设置→应用→应用和功能 卸载nodejs即可 2. 安装nvm,地址:https://github.com/coreybutler/nvm-windows/releases 安装目录时尽量不要出现特殊字符还有空格,否则会在nvm use xxx的…

mysql实现隔离性——锁

锁主要解决写-写问题,mvcc用来解决读-写问题 MyISAM不使用行级锁,主要使用表锁 MyISAM存储引擎主要使用表锁(table-level locking),并不支持行级锁(row-level locking)。当MyISAM存储引擎执行…

OpenCV人脸识别,报错缺少haarcascade_frontalface_default.xml文件解决方案(随手记)

使用pip安装的opencv库可能会缺少进行人脸识别的haarcascade_frontalface_default.xml等文件。 可以通过github直接进行下载,再放到需要使用的python文件目录下 单击连接,github人脸识别库-link 找到对应需要的xml文件,这里我举例为haarcas…

01软件下载安装和P解

凯哥英语视频 软件下载安装和P解 凯哥英语视频1.官网直接下,专业版安装不会有人不会吧实在下载不到就去我这百度云吧结语 1.官网直接下,专业版 点击前往逛网下载https://www.jetbrains.com/pycharm/ 下载专业版,奶茶外卖都能点,只…

《企业科技与发展》是什么级别的期刊?是正规期刊吗?

问题解答 问:《企业科技与发展》期刊怎么样? ​答:企业科技与发展》(月刊)1985年创刊,由广西科学技术厅主管、广西科学技术情报研究所主办,国内外公开发行。主要栏目:科技对策与研究、企业科技…

优化Mac系统,TinkerTool一键掌控!

TinkerTool System for Mac是一款专为Mac用户设计的系统设置维护工具。这款软件不仅具备执行系统维护任务的能力,如管理文件和调整系统或用户设置,还包含一系列功能强大的工具,旨在帮助用户解决、修复、排除故障或修复系统错误和损坏的帐户等…

大企业总部与分部组网方案

在全球化的经济环境中,大企业往往设有总部和多个地理分散的分部。为了确保信息的快 速流通、资源的优化配置以及管理的高效运作,构建一个稳定、安全且高效的组网方案显 得尤为重要。本文将探讨大企业如何通过技术手段和管理策略,实现总部与分…

Python专题:十三、日期和时间(2)

datetime 模块 today()函数 date类型 year month day