Power Query中的VLOOKUP - 合并查询

2024-02-08 04:48

本文主要是介绍Power Query中的VLOOKUP - 合并查询,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

转载于https://zhuanlan.zhihu.com/p/31280825

首发于从Excel 到 Power BI 数据分析可视化

关注专栏写文章

 

Power Query中的VLOOKUP - 合并查询

Power Query中的VLOOKUP - 合并查询

赵文超

赵文超

商业数据分析师。公众号:powerpivotworks

​关注他

18 人赞同了该文章

VLOOKUP是EXCEL函数里的大众情人,但是大家对TA是既爱又恨:简单方便,但是一旦数据量上升到数十万量级就开始耍小脾气了,时不时就会出现未响应,接下来我们来扒一扒Vlookup的替代方案。

 

在PowerPivot中我们可以创建两个表之间的关系,通过DAX中Related解决,但是虽然能够得到数据,却不能导出到EXCEL中,眼看得到了解决,却还是拿不到结果,那么我们该怎么得到结果呢?

这时,我们可以思考一个问题,我们想要的是另一表中匹配列,Vlookup就是通过查找与此相对应的数据得到匹配列,那么我们可以联想下查询中的哪些功能可以使用。突然想到Excel Power Query教程中有一节是关于生成笛卡尔积表,利用的是合并查询的功能。那么合并查询是否也能够解决现在的问题呢?

我们来试一试就知道了?,图1是两个表,一个是人员信息表,一个是匹配表。

 

我们将这两个表导入到查询中:

 

想要在人员信息表中增加入职日期信息,那么要先选中人员信息表,然后再选择匹配表,将两个表中的ID列分别选中,如下图

 

点击确定,得到以下结果

 

可以看到增加了一个新列,展开选择扩展入职日期:

 

确定之后选择关闭并上载,就可以得到结果了,是不是又快又简单,而且如果有数据更改一键刷新就可以了,再也不用担心数据出错了,再也不用担心Vlookup的小脾气咯!!!

问题得到解决了,可是上面的步骤中应该还有一个小疑问,我们在图2中可以看到有联接种类的选项,展开可以看到如下

 

总共有6个选项,那么TA们有什么区别呢?
我们用一个简单的例子来说明一下:

 

如果选择左外部:

 

如果选择右外部:

 

如果选择完全外部:

 

如果选择内部:

 

如果选择左反:

 

如果选择右反:

 

总结:
左外部——保留表1 的所有项目,同时查询表2 和表1 的匹配项,排除表2 的不匹配项;
右外部——保留表2 的所有项目,同时查询表1 和表2 的匹配项,排除表1 的不匹配项;
完全外部——保留表1和表2 的所有项目;
内部——仅保留表1 和表2 的完全匹配项,排除其他项目;
左反——保留表1与表2 有差异的全部数据,排除表1 和表2 的匹配项;
右反——保留表2与表1有差异的全部数据,排除表2和表1 的匹配项。

 

好了,今天说了那么多,不知道你是听明白了,还是听糊涂了呢?

 

*PowerPivot工坊原创文章,转载请注明出处!

----------------------------------------------------------------------------------------------

这篇关于Power Query中的VLOOKUP - 合并查询的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/689936

相关文章

浅谈mysql的sql_mode可能会限制你的查询

《浅谈mysql的sql_mode可能会限制你的查询》本文主要介绍了浅谈mysql的sql_mode可能会限制你的查询,这个问题主要说明的是,我们写的sql查询语句违背了聚合函数groupby的规则... 目录场景:问题描述原因分析:解决方案:第一种:修改后,只有当前生效,若是mysql服务重启,就会失效;

MySQL多列IN查询的实现

《MySQL多列IN查询的实现》多列IN查询是一种强大的筛选工具,它允许通过多字段组合快速过滤数据,本文主要介绍了MySQL多列IN查询的实现,具有一定的参考价值,感兴趣的可以了解一下... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析与优化1.

Python实现合并与拆分多个PDF文档中的指定页

《Python实现合并与拆分多个PDF文档中的指定页》这篇文章主要为大家详细介绍了如何使用Python实现将多个PDF文档中的指定页合并生成新的PDF以及拆分PDF,感兴趣的小伙伴可以参考一下... 安装所需要的库pip install PyPDF2 -i https://pypi.tuna.tsingh

mybatis-plus 实现查询表名动态修改的示例代码

《mybatis-plus实现查询表名动态修改的示例代码》通过MyBatis-Plus实现表名的动态替换,根据配置或入参选择不同的表,本文主要介绍了mybatis-plus实现查询表名动态修改的示... 目录实现数据库初始化依赖包配置读取类设置 myBATis-plus 插件测试通过 mybatis-plu

MySQL中实现多表查询的操作方法(配sql+实操图+案例巩固 通俗易懂版)

《MySQL中实现多表查询的操作方法(配sql+实操图+案例巩固通俗易懂版)》本文主要讲解了MySQL中的多表查询,包括子查询、笛卡尔积、自连接、多表查询的实现方法以及多列子查询等,通过实际例子和操... 目录复合查询1. 回顾查询基本操作group by 分组having1. 显示部门号为10的部门名,员

mysql关联查询速度慢的问题及解决

《mysql关联查询速度慢的问题及解决》:本文主要介绍mysql关联查询速度慢的问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql关联查询速度慢1. 记录原因1.1 在一次线上的服务中1.2 最终发现2. 解决方案3. 具体操作总结mysql

使用Apache POI在Java中实现Excel单元格的合并

《使用ApachePOI在Java中实现Excel单元格的合并》在日常工作中,Excel是一个不可或缺的工具,尤其是在处理大量数据时,本文将介绍如何使用ApachePOI库在Java中实现Excel... 目录工具类介绍工具类代码调用示例依赖配置总结在日常工作中,Excel 是一个不可或缺的工http://

mysql线上查询之前要性能调优的技巧及示例

《mysql线上查询之前要性能调优的技巧及示例》文章介绍了查询优化的几种方法,包括使用索引、避免不必要的列和行、有效的JOIN策略、子查询和派生表的优化、查询提示和优化器提示等,这些方法可以帮助提高数... 目录避免不必要的列和行使用有效的JOIN策略使用子查询和派生表时要小心使用查询提示和优化器提示其他常

使用Python创建一个能够筛选文件的PDF合并工具

《使用Python创建一个能够筛选文件的PDF合并工具》这篇文章主要为大家详细介绍了如何使用Python创建一个能够筛选文件的PDF合并工具,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录背景主要功能全部代码代码解析1. 初始化 wx.Frame 窗口2. 创建工具栏3. 创建布局和界面控件4

Python自动化办公之合并多个Excel

《Python自动化办公之合并多个Excel》在日常的办公自动化工作中,尤其是处理大量数据时,合并多个Excel表格是一个常见且繁琐的任务,下面小编就来为大家介绍一下如何使用Python轻松实现合... 目录为什么选择 python 自动化目标使用 Python 合并多个 Excel 文件安装所需库示例代码