百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

VBA合并文件夹下多个excel文件到一个工作表操作步骤

liuian 2025-02-06 15:41 41 浏览

要将多个Excel文件的工作表内容合并到一个单独的工作表中,你可以使用以下的VBA宏代码。这个宏会遍历一个指定的文件夹,打开每个Excel文件,将其中第一个工作表(或你可以指定的工作表)的内容复制到一个新的或指定的目标工作簿的单一工作表中。

以下是详细的VBA代码示例:

vba

复制以下代码:

Sub MergeExcelFilesToOneSheet()

Dim folderPath As String

Dim fileName As String

Dim wbSource As Workbook

Dim wsSource As Worksheet

Dim wbTarget As Workbook

Dim wsTarget As Worksheet

Dim lastRow As Long

' 让用户选择包含Excel文件的文件夹

With Application.FileDialog(msoFileDialogFolderPicker)

.Title = "请选择一个包含Excel文件的文件夹"

If .Show = -1 Then

folderPath = .SelectedItems(1) & "\"

Else

MsgBox "未选择文件夹,操作已取消。", vbExclamation

Exit Sub

End If

End With

' 创建一个新的工作簿作为目标工作簿

Set wbTarget = Workbooks.Add

Set wsTarget = wbTarget.Sheets(1)

' 禁用屏幕更新以提高效率

Application.ScreenUpdating = False

' 获取文件夹中的第一个Excel文件名

fileName = Dir(folderPath & "*.xls*")

' 遍历文件夹中的所有Excel文件

Do While fileName <> ""

' 打开当前文件

Set wbSource = Workbooks.Open(folderPath & fileName)

' 假设要合并的是第一个工作表,可以根据需要修改

Set wsSource = wbSource.Sheets(1)

' 找到目标工作表的最后一行

lastRow = wsTarget.Cells(wsTarget.Rows.Count, "A").End(xlUp).Row

' 如果目标工作表为空,则直接复制整个工作表内容

If lastRow = 1 Then

wsSource.UsedRange.Copy Destination:=wsTarget.Range("A1")

Else

' 否则,复制工作表的内容到目标工作表的末尾

wsSource.UsedRange.Offset(1, 0).Copy Destination:=wsTarget.Cells(lastRow + 1, 1)

End If

' 关闭当前文件,不保存更改

wbSource.Close SaveChanges:=False

' 释放内存

Set wbSource = Nothing

Set wsSource = Nothing

' 获取下一个文件名

fileName = Dir

Loop

' 恢复屏幕更新

Application.ScreenUpdating = True

' 通知用户合并完成

MsgBox "所有文件的工作表内容已成功合并到一个工作表中!", vbInformation

End Sub


代码解释

?文件夹选择?:使用FileDialog对象让用户选择一个包含Excel文件的文件夹。

?目标工作簿创建?:使用Workbooks.Add创建一个新的工作簿作为目标工作簿,并设置其第一个工作表为目标工作表。

?屏幕更新控制?:为了提高宏的执行效率,使用
Application.ScreenUpdating来关闭屏幕更新。

?文件遍历?:使用Dir函数遍历文件夹中的所有Excel文件。

?工作表内容复制?:

对于每个文件,打开它并获取其第一个工作表。

找到目标工作表的最后一行。

如果目标工作表为空,则复制整个工作表内容到目标工作表的起始位置。

如果目标工作表不为空,则复制工作表的内容(不包括标题行)到目标工作表的末尾。

?文件关闭?:关闭当前文件,不保存更改,并释放相关内存。

?屏幕更新恢复?:数据合并完成后,恢复屏幕更新。

?完成通知?:通过消息框通知用户,所有文件的工作表内容已成功合并到一个工作表中。

使用方法

打开Excel,按Alt + F11进入VBA编辑器。

插入一个新模块(Insert -> Module)。

将上述代码粘贴到新模块中。

按F5键或点击运行按钮来执行宏。

根据提示选择包含待合并Excel文件的文件夹。

等待宏执行完成,合并后的数据将出现在一个新的工作簿的单一工作表中。

请确保所有待合并的Excel文件的工作表结构相同(即列数和列的顺序相同),以便数据能够正确合并。如果工作表结构不同,你可能需要对代码进行适当调整。

相关推荐

python入门到脱坑函数—定义函数_如何定义函数python

Python函数定义:从入门到精通一、函数的基本概念函数是组织好的、可重复使用的代码块,用于执行特定任务。在Python中,函数可以提高代码的模块性和重复利用率。二、定义函数的基本语法def函数名(...

javascript函数的call、apply和bind的原理及作用详解

javascript函数的call、apply和bind本质是用来实现继承的,专业点说法就是改变函数体内部this的指向,当一个对象没有某个功能时,就可以用这3个来从有相关功能的对象里借用过来...

JS中 call()、apply()、bind() 的用法

其实是一个很简单的东西,认真看十分钟就从一脸懵B到完全理解!先看明白下面:例1obj.objAge;//17obj.myFun()//小张年龄undefined例2shows(...

Pandas每日函数学习之apply函数_apply函数python

apply函数是Pandas中的一个非常强大的工具,它允许你对DataFrame或Series中的数据应用一个函数,可以是自定义的函数,也可以是内置的函数。apply可以作用于DataF...

Win10搜索不习惯 换个设定就好了_window10搜索用不了怎么办

Windows10的搜索功能是真的方便,这点用惯了Windows10的小伙伴应该都知道,不过它有个小问题,就是Windows10虽然会自动联网搜索,但默认使用微软自家的Bing搜索引擎和Edge...

面试秘籍:call、bind、apply的区别,面试官为什么总爱问这三位?

引言你有没有发现,每次JavaScript面试,面试官总爱问你call、bind和apply的区别?好像这三个方法成了通关密码,掌握了它们,就能顺利过关。其实不难理解,面试官问这些问题,不...

记住这8招,帮你掌握“追拍“摄影技法—摄影早自习第422日

杨海英同学提问:请问叶梓老师,我练习追拍时,总也不能把运动的人物拍清晰,速度一般掌握在1/40-1/60,请问您如何把追拍拍的清晰?这跟不同的运动形式有关系吗?请您给讲讲要点,谢谢您!摄影:Damia...

[Sony] 有点残酷的测试A7RII PK FS7

都是好机!手中利器!主要是最近天天研究fs5,想知道fs5与a7rii后期匹配问题,苦等朋友的fs5月底到货,于是先拿手里现有的fs7小测一下,十九八九也能看到fs5的影子,另外也了解一下fs5k标配...

AndroidStudio_Android使用OkHttp发起Http请求

这个okHttp的使用,其实网络上有很多的案例的,但是,如果以前没用过,copy别人的直接用的话,可以发现要么导包导不进来,要么,人家给的代码也不完整,这里自己整理一下.1.引入OkHttp的jar...

ESL-通过事件控制FreeSWITCH_es事务控制

通过事件提供的最底层控制机制,允许我们有效地利用工具箱,适时选择使用其中的单个工具。FreeSWITCH是一个核心交换与混合矩阵,它周围有几十个模块提供各种功能特性。我们完全控制了所有的即时信息,这些...

【调试】perf和火焰图_perf生成火焰图

简介perf是linux上的性能分析工具,perf可以对event进行统计得到event的发生次数,或者对event进行采样,得到每次event发生时的相关数据(cpu、进程id、运行栈等),利用这些...

文本检索控件也玩安卓?dtSearch Engine发布Android测试版

dtSearchEngineforLinux(原生64-bit/32-bitC++和JavaAPIs)和dtSearchEngineforWin&.NET(原生64-bi...

网站后台莫名增加N个管理员,记一次SQL注入攻击

网站没流量,但却经常被SQL注入光顾。最近,网站真的很奇怪,网站后台不光莫名多了很多“管理员”,所有的Wordpres插件还会被自动暂停,导致一些插件支持的页面,如WooCommerce无法正常访问、...

多元回归树分析Multivariate Regression Trees,MRT

多元回归树(MultivariateRegressionTrees,MRT)是单元回归树的拓展,是一种对一系列连续型变量递归划分成多个类群的聚类方法,是在决策树(decision-trees)基础...

JMETER性能测试_JMETER性能测试指标

jmeter为性能测试提供了一下特色:jmeter可以对测试静态资源(例如js、html等)以及动态资源(例如php、jsp、ajax等等)进行性能测试jmeter可以挖掘出系统最大能处...