ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 Excel Home精品图文教程库
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
300集Office 2010微视频教程 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 66674|回复: 58

[分享] 不用VBA,不用SQL语句,且看 POWER QUERY 快速合并多个Excel工作簿

  [复制链接]

TA的精华主题

TA的得分主题

发表于 2015-3-11 14:05 | 显示全部楼层 |阅读模式
本帖已被收录到知识树中,索引项:其他官方插件
本帖最后由 张文洲 于 2016-9-1 11:20 编辑

最近看到关于用Power Query(以下简称PQ)合并同一文件夹下Excel工作簿某固定名称工作表的示例,得到启发,研究了用PQ合并文件夹(含子文件夹)下所有Excel工作表所有工作表的方法,特和大家分享。

关于什么是PQ,PQ的基础应用知识,之前我已经写了两篇帖子,有兴趣的学友可以看看
快来学习 Power Query 吧,屌爆了的Excel加载项

一步综合介绍 Power Query 使用方法
更多视频: 更多视频操作教程.rar (170 Bytes, 下载次数: 733)
不需要使用VBA和SQL语句,就能快速合并工作簿,用PQ实现的步骤如下:

一、模拟数据背景
    我桌面有一个文件夹“父文件夹”,里面有两个工作簿 车间1和车间2,还有一个子文件夹,子文件夹里面同样有两个工作簿,车间3和车间4。四个工作簿里面各有5张工作表,工作表名称分别为1月、2月、3月、4月、5月。每张工作表内容是一样的,两列,名称和数量。
为便于理解,以下是截图。
1.jpg

2.jpg

3.jpg

二、查看PO查询语句,构建自定义函数
1、PO选项卡-从文件-从文件夹

5.jpg

6.jpg

8.jpg

2、导入文件夹及文件目录信息以后,看到里面有路径及文件名称的信息,这是之后要用到的。
9.jpg
3、可以看到父文件夹下所有工作簿信息都已经列示出来,我们单击第一列标题左边扩展按钮,

11.jpg
4.这里显示了第一个工作簿5张工作表名称,第二列,当我们单击某一格,会立即显示该月份的数据。这里我们需要
所有工作表的数据,因此先点data标题右边扩展按钮
12.jpg
去掉最下面的默认√,点确定
16.jpg
看看,这里已经显示了车间1月份1到月份5的全部数据,包括标题行。我们且用筛选去掉标题行
17.jpg
筛选第二列=名称的所有行
18.jpg

然后切换到视图选项卡,点高级编辑器

19.jpg
在编辑器里面看到一串代码,不懂不要紧,只看到里面唯一的自定义内容就是文件路径(注意路径最末尾没有\分隔符),我们且在这段代码首位各加一句,然后把路径各一个自定义变慢名称
20.jpg

这里实际上是构建了一个名为 combdata 的自定义函数,有一个参数folderpath
21.jpg
我们点完成,并给这个查询定义一个熟悉的名称Combdata

25.jpg

切换到开始选项卡,点关闭并上载

23.jpg

如此,右边已经建立了一个自定义函数

26.jpg

三、应用自定义函数提取数据

接下来新建一个连接,从文件夹导入数据,注意到路径列,最后又一个\符号,我们需要去掉。
PQ里面有两个函数,一个是 Text.Length ,相当于工作表中 len函数,另一个 Text.Start ,相当于 工作表 left函数。
特别要强调的是,PQ函数严格区分大小写,不同于工作表函数
我们只需要用
Text.Start([Folder Path],Text.Length([Folder Path])-1)  就可以去掉最末尾的 \ 符号了
这个公式结果就可以供前面设计的自定义函数 Combdata作为参数使用了
我们添加一个自定义列,设置公式为
=Combdata(Text.Start([Folder Path],Text.Length([Folder Path])-1))




52.jpg
53.jpg

看看,多出了一列自定义列,内容显示的都table类型哦


28.jpg

同样,我们扩展最后一列看看效果

29.jpg

这里已经将4个工作簿20张工作表全部合并起来了。我们删除不要的列,就可以加载到工作表了,右键可以刷新

30.jpg


31.jpg


33.jpg


以上介绍完毕

需要注意的细节:
1、以上为了合并文件夹(含子文件夹)全部工作表所有工作表的数据,因此第一次构建函数时用的是从文件夹导入数据,在此基础上更改查询代码。
如果只是合并某特定文件夹(不含子文件夹)或者某特定工作表(如所有工作簿的第一张工作表1月),那么可以使用从工作簿导入数据的方式,在此基础上修改代码构建函数,相对也简单的多。
2、PQ中的函数,比工作表函数丰富多了,也严格区分大小写。如Text.Length  中两个大写字母不能小写,其他小写字母也不能大写。
3、构建PQ自定义函数以后,一定记得将查询名称重新定义一下,默认的是查询1,我上面改成了Combdata,注意后面自定义列中调用这个函数时用的是这个名称而不是代码中的 combdata  ,当然也可以不重新定义,直接用 查询1(参数)的形式调用。
4、关于PQ函数和语法的有关知识在哪里可以找得到呢?我在前面第一个基础帖中已经介绍了,

56.jpg
5、俗话说,举一反三,上面介绍了合并Excel工作簿的方法,那么类似于Text格式文件或者网页表格,是不是也可以用类似的方法来实现呢?
6、听说新一版的office预览版已经发布了,PQ不在作为Excel的外置插件,而是继承在Excel程序本身,不知道是否属实。不过从PQ的函数规范和语法规范来看,微软还是在这一块投入了不少精力。
就PQ函数而言,其无论是从数量还是功能来看,都比工作表函数丰富且强大的多,很多原来我们需要用VBA自定义函数实现的功能,这里面500多个函数,相信会让你惊喜不断。7、载入到Excel工作表以后,请在表属性中取消勾选自动调整列宽,这样会是刷新效率提高






评分

5

查看全部评分

TA的精华主题

TA的得分主题

发表于 2015-3-11 14:11 | 显示全部楼层
不明觉厉。我怎么感觉比VBA更复杂。
也许是不熟悉的原因吧

TA的精华主题

TA的得分主题

 楼主| 发表于 2015-3-11 14:17 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
cc1027cc 发表于 2015-3-11 14:11
不明觉厉。我怎么感觉比VBA更复杂。
也许是不熟悉的原因吧

这个比VBA简单多了,单纯的SQL查询语句也得与VBA结合才能遍历所有工作簿和工作表

TA的精华主题

TA的得分主题

发表于 2015-3-11 14:21 | 显示全部楼层
张文洲 发表于 2015-3-11 14:17
这个比VBA简单多了,单纯的SQL查询语句也得与VBA结合才能遍历所有工作簿和工作表

以后有空了学习下
呵呵。只知道POWER POVIOT和 MICRO QUERY
这个难道是两者的结合
嘿嘿

TA的精华主题

TA的得分主题

发表于 2015-3-11 22:41 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
高大上的好东西,要学习啊!

TA的精华主题

TA的得分主题

发表于 2015-3-12 08:05 来自手机 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2015-3-12 13:17 | 显示全部楼层
用类似的原理合并网页列表多页数据也可以实现。我这里合并了本论坛某板块前5页的数据
1.png

TA的精华主题

TA的得分主题

发表于 2015-3-20 22:27 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
真的高大上。

TA的精华主题

TA的得分主题

发表于 2015-7-28 07:25 | 显示全部楼层
请问,每个工作簿的工作表名称是否可以不一致?

TA的精华主题

TA的得分主题

发表于 2015-7-28 11:30 | 显示全部楼层
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

关闭

最新热点上一条 /1 下一条

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-4-19 21:30 , Processed in 0.045561 second(s), 11 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表