干货丨Power Query 数据类型及数据结构
查询增强版(Power Query)是Excel Power BI组件中用于数据导入、数据整合以及数据处理的插件工具。适用于Excel 2010以上版本,在Excel 2010以及Excel 2013中需要下载插件安装加载后使用,在Excel 2016版本中Power Query被内置在数据选项卡的获取和转换工具集中。在Power Query帮助下,Excel不再受限于数据的行数限制,可以快速关联并整合多种来自不同数据源的数据信息,可以像数据库一样对表结构数据进行加工整理。Power Query令Excel从制表工具华丽变身为数据综合处理平台......
晦涩难懂的IT语言到此为止,说点好懂的就是使用Power Query可以帮助各位早干完活儿早回家、可以帮助大家在团队中脱颖而出升职加薪。未来你说你不懂Power Query,可能在“表圈”就混不下去了。
在众多Power Query的使用者中也是存在鄙视链的:
本系列文章主要向大家系统介绍鄙视链中上边两层关于M函数的内容。至于Power Query的基本操作相关内容,还请大家通过度娘或是报名我的Excel BI相关课程了解学习。
M函数是Power Query专用的函数语法,使用M函数可以帮助我们自由灵活地完成数据导入、整合、加工处理等任务工作。Power Query的界面操作只能发挥其全部能力的20%,剩余80%的能力都要通过M函数来实现。
M函数在使用方法上与Excel的基本函数功能完全不同,M函数更像是一门专用于数据处理的编程语言,学习M函数首先我们要了解它的基本表达式、数据类型以及数据结构。下边就着重为大家介绍这三方面内容。
※大家可以在Power Query的查询编辑器内新建空查询,并在视图选项卡内的高级编辑器中复制案例代码了解每个案例代码的执行结果。
※ //符号为M语句的注释符
M函数基本表达式:
let…in…结构:
let用于封装计算结果,并为计算结果命名。
in用于显示结果
例:
let
Source = Text.Proper("hello world")
in
Source
解说:
通过let语句将Text.Proper(“hello world”)函数的计算结果封装到名叫Source的变量中,再通过in语句显示Source变量的内容“hello world”。
M函数基本变量:
自定义函数:
函数名 = (参数1,参数2,参数3……) => 函数运算表达式
※通过调用函数得到的函数返回值称为函数值
例:
let
MyFunction = (parameter1, parameter2) =>(parameter1+ parameter2) / 2
Final = MyFunction(2,4)
in
Final
解说:
以上代码执行结果为3,先在let中创建名为MyFunction的自定义函数,函数有parameter1和parameter2两个参数,函数的运算表达式为(parameter1 + parameter2) / 2,之后在let中使用2与4两个参数调用MyFunction函数,MyFunction函数将运算结果返回给变量Final,最后在in中显示Final变量的内容3。
结构化数值
1. 列表(List):
列表是扩在花括号中的一组数据,列表中每个数据都有属于自己的序号以便自己能够被检索到,列表中的数据序号从0开始按照排列顺序依次整数递增,大列表内还可以嵌套子列表、记录等。花括号除了用来括起列表内的所有数据还用来指定列表内数据的序号,通过指定数据序号可以从列表内找到并获取所需的数据值。
2. 记录(Record):
记录用来定义字段和给字段赋值,一个字段由字段名以及字段内的值组成,字段名是唯一的文本值,是字段的标识符。字段名可以不用引号引用,字段名有两种表达形式:
> 不加""的表达形式、例如OrderID
> 加#和""的表达形式、例如#"Today's data is:"
记录中的内容写在[]括号内,[]括号同样用于在记录中取特定字段的值。
例1:定义字以及显示记录内所有内容
let Source =
[
OrderID = 1,
#"CustomerID" = 1,
Item = "Fishing rod",
Price = 100.00
]
in Source
例2:定义字以及显示记录内[Item]字段的值
let Source =
[
OrderID = 1,
#"CustomerID" = 1,
Item = "Fishing rod",
Price = 100.00
]
in Source[#"CustomerID"] //equals 1
3. 表(Table):
表是由行列数据构成的,可以使用隐式或显示方式定义字段(列)的数据类型。使用#table建表时,可以使用列表或者记录来定义列名,并使用嵌套列表来定义表中的数据,嵌套列表的大列表内包含所有定义单行用的子列表,而每个子列表则用来定义一行数据。花括号{}可以用来索引查找指定行的数据。
例1:隐式字段表
let
Source = #table(
{"OrderID", "CustomerID", "Item","Price"},
{
{1, 1, "Fishing rod", 100.00},
{2, 1, "1 lb. worms", 5.00}
})
in Source
例2:显示字段表
let
Source = #table(
type table [OrderID = number, CustomerID = number, Item = text, Price = number],
{
{1, 1, "Fishing rod",100.00},
{2, 1, "1 lb. worms", 5.00}
}
)
in Source
例3:建表后取表中第一行数据
let
Source = #table(
type table [OrderID = number, CustomerID = number, Item = text, Price =number],
{
{1, 1, "Fishing rod", 100.00},
{2, 1, "1 lb. worms", 5.00}
}
)
in Source{1}
其他数据结构案例:
数据结构中可以包含任意M值,以下为一些案例:
例1:复合数据结构的列表
let
Source =
{
1, //数值
"Bob", //文本
DateTime.ToText(DateTime.LocalNow(), "yyyy-MM-dd"), //函数值
[OrderID = 1, CustomerID = 1, Item = "Fishing rod", Price =100.0] //记录
}
in
Source
例2:包含子列表的记录
let
Source = [CustomerID = 1, Name = "Bob", Phone ="123-4567", Orders =
{
[OrderID = 1, CustomerID = 1, Item = "Fishing rod", Price =100.0],
[OrderID = 2, CustomerID = 1, Item = "1 lb. worms", Price =5.0]
}]
in
Source
if表达式:
if表达式通过对逻辑条件进行判断来对两个表达式进行选择。
例:
if 2 > 1 then
2 +2
else
1 +1
解说:
在上述案例中,因为判断条件2>1的逻辑值为真,所以执行第一个表达式2+2,所以执行结果为4,如果判断条件改为2<1,则其判断条件的逻辑值为假,所以会执行第二个表达式1+1,此时的执行结果为2.
Power Query 是 Power BI 系列插件中的一款重要插件,用以弥补传统 Excel 功能在数据处理方面的不足,如果你对Excel Power BI黑科技感兴趣,欢迎参加由微软MVP李奇老师主讲CDA数据分析员课程。
报名:
扫描二维码或点击阅读原文
扫描二维码报名参加
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
你是否被统计学复杂的理论和晦涩的公式劝退过?别担心,“山有木兮:统计学极简入门(Python)” 将为你一一化解这些难题。课程 ...
2025-03-31在电商、零售、甚至内容付费业务中,你真的了解你的客户吗? 有些客户下了一两次单就消失了,有些人每个月都回购,有些人曾经是 ...
2025-03-31在数字化浪潮中,数据驱动决策已成为企业发展的核心竞争力,数据分析人才的需求持续飙升。世界经济论坛发布的《未来就业报告》, ...
2025-03-28你有没有遇到过这样的情况?流量进来了,转化率却不高,辛辛苦苦拉来的用户,最后大部分都悄无声息地离开了,这时候漏斗分析就非 ...
2025-03-27TensorFlow Datasets(TFDS)是一个用于下载、管理和预处理机器学习数据集的库。它提供了易于使用的API,允许用户从现有集合中 ...
2025-03-26"不谋全局者,不足谋一域。"在数据驱动的商业时代,战略级数据分析能力已成为职场核心竞争力。《CDA二级教材:商业策略数据分析 ...
2025-03-26当你在某宝刷到【猜你喜欢】时,当抖音精准推来你的梦中情猫时,当美团外卖弹窗刚好是你想吃的火锅店…… 恭喜你,你正在被用户 ...
2025-03-26当面试官问起随机森林时,他到底在考察什么? ""请解释随机森林的原理""——这是数据分析岗位面试中的经典问题。但你可能不知道 ...
2025-03-25在数字化浪潮席卷的当下,数据俨然成为企业的命脉,贯穿于业务运作的各个环节。从线上到线下,从平台的交易数据,到门店的运营 ...
2025-03-25在互联网和移动应用领域,DAU(日活跃用户数)是一个耳熟能详的指标。无论是产品经理、运营,还是数据分析师,DAU都是衡量产品 ...
2025-03-24ABtest做的好,产品优化效果差不了!可见ABtest在评估优化策略的效果方面地位还是很高的,那么如何在业务中应用ABtest? 结合企业 ...
2025-03-21在企业数据分析中,指标体系是至关重要的工具。不仅帮助企业统一数据标准、提升数据质量,还能为业务决策提供有力支持。本文将围 ...
2025-03-20解锁数据分析师高薪密码,CDA 脱产就业班助你逆袭! 在数字化浪潮中,数据驱动决策已成为企业发展的核心竞争力,数据分析人才的 ...
2025-03-19在 MySQL 数据库中,查询一张表但是不包含某个字段可以通过以下两种方法实现:使用 SELECT 子句以明确指定想要的字段,或者使 ...
2025-03-17在当今数字化时代,数据成为企业发展的关键驱动力,而用户画像作为数据分析的重要成果,改变了企业理解用户、开展业务的方式。无 ...
2025-03-172025年是智能体(AI Agent)的元年,大模型和智能体的发展比较迅猛。感觉年初的deepseek刚火没多久,这几天Manus又成为媒体头条 ...
2025-03-14以下的文章内容来源于柯家媛老师的专栏,如果您想阅读专栏《小白必备的数据思维课》,点击下方链接 https://edu.cda.cn/goods/sh ...
2025-03-13以下的文章内容来源于刘静老师的专栏,如果您想阅读专栏《10大业务分析模型突破业务瓶颈》,点击下方链接 https://edu.cda.cn/go ...
2025-03-12以下的文章内容来源于柯家媛老师的专栏,如果您想阅读专栏《小白必备的数据思维课》,点击下方链接 https://edu.cda.cn/goods/sh ...
2025-03-11随着数字化转型的加速,企业积累了海量数据,如何从这些数据中挖掘有价值的信息,成为企业提升竞争力的关键。CDA认证考试体系应 ...
2025-03-10