干货丨Power Query 数据类型及数据结构-阿里云开发者社区

开发者社区> 技术小能手> 正文

干货丨Power Query 数据类型及数据结构

简介: 本系列文章主要向大家系统介绍鄙视链中上边两层关于M函数的内容。
+关注继续查看

前言

查询增强版(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的使用者中也是存在鄙视链的:

image

本系列文章主要向大家系统介绍鄙视链中上边两层关于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函数基本变量:

image

自定义函数:
函数名 = (参数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开始按照排列顺序依次整数递增,大列表内还可以嵌套子列表、记录等。花括号除了用来括起列表内的所有数据还用来指定列表内数据的序号,通过指定数据序号可以从列表内找到并获取所需的数据值。


image

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
  1. 表(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.

原文发布时间为:2018-07-11
本文作者:Excel-BI 李奇
本文来自云栖社区合作伙伴“ CDA数据分析师”,了解相关信息可以关注“CDA数据分析师

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
9756 0
jquery插件整理篇(九)数据验证类
1. jQuery plugin: Validation jQuery校验插件。jQuery plugin: Validation 2. Masked Input Plugin 热点图书:www.hotbook.cn Masked Input这个jQuery插件让用户能够按照预先设定好的固定格式输入数据(如日期、电话号码等)。
954 0
PowerDesigner教程系列(三)概念数据模型
原文http://www.cnblogs.com/yxonline/archive/2007/04/09/705718.html 目标:本文主要介绍属性的标准检查约束、如何定义属性的附加检查。一、定义属性的标准检查约束标准检查约束是一组确保属性有效的表达式。
782 0
PowerDesigner教程系列(五)概念数据模型
原文http://www.cnblogs.com/yxonline/archive/2007/04/11/708387.html 目标:本文主要介绍数据项、新增数据项、数据项的唯一性代码选项和重用选项等。
683 0
使用PowerDesigner生成数据库测试数据
原文http://blog.csdn.net/horace20/article/details/6672081 特别说明:本文产生于个人工作总结,转载请注明原文出处http://blog.csdn.net/horace20 1、环境        PowerDesigner15.2.0.3042-BEAN+ MySQL5.5 + mysql-connector-odbc-5.1.8        以上软件在网上都很容易找到,这里就不再给出相关链接!系统环境为WindowsXP。
1029 0
power designer pdm生成sql脚本和数据库以及逆向工程
正向工程:PDM---&gt;sql or database 项目中我们经常需要根据PDM生成sql脚本,然后由sql脚本一起执行到数据库中,如果PDM中表比较多,我们一个个去建的话会很费时间,根据需要我们也可以直接将pdm生成到数据库中。 逆向工程:sql or database ---&gt;PDM 有时我们也需要根据sql脚本生成pdm图,或者是数据库的最新信息生成到PDM中
1452 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系.
13478 0
PostgreSQL中同样是别人提交的数据,为什么你能看到,我却看不到?
阅读使人充实,讨论使人敏捷,写作使人精确。
504 0
+关注
技术小能手
云栖运营小编~
7208
文章
9
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载