网站首页 > 技术文章 正文
本VBA代码设计用于合并同一文件夹下所有Excel文件(包括 .xls 和 .xlsx 格式)中结构相同的工作表数据,生成一个包含所有数据的综合工作表。代码通过文件系统对象(FSO)自动遍历指定文件夹中的Excel文件,提取每个工作表的数据并将其合并到新建的工作表中,仅保留一次表头。代码包含详细注释,便于理解和维护,适合需要批量整合Excel数据的场景。运行前,请确保所有工作表具有一致的表头结构,并正确设置文件夹路径,以保证合并结果的准确性和完整性。
Sub MergeExcelFiles()
' 声明变量
Dim fso As Object ' 文件系统对象,用于处理文件夹和文件
Dim folder As Object ' 文件夹对象
Dim file As Object ' 文件对象
Dim wb As Workbook ' 当前处理的Excel文件工作簿对象
Dim ws As Worksheet ' 循环处理的工作表对象
Dim wsMaster As Worksheet ' 合并结果的目标工作表
Dim rng As Range ' 数据范围
Dim lastRow As Long ' 最后一行号
Dim lastCol As Long ' 最后一列号
Dim targetRow As Long ' 目标工作表的当前行号
Dim firstDataRow As Long ' 数据开始行(通常为第2行,跳过表头)
Dim folderPath As String ' 文件夹路径
Dim fileExtension As String ' 文件扩展名
Dim app As Application ' Excel应用程序对象
' 设置错误处理
On Error GoTo ErrorHandler
' 初始化Excel应用程序对象
Set app = Application
' 设置文件夹路径(可修改为实际路径或使用文件夹选择对话框)
folderPath = "C:\YourFolderPath\" ' 请替换为实际文件夹路径
fileExtension = "*.xls*" ' 兼容.xls和.xlsx文件
' 创建文件系统对象
Set fso = CreateObject("Scripting.FileSystemObject")
' 检查文件夹是否存在
If Not fso.FolderExists(folderPath) Then
MsgBox "指定的文件夹路径不存在: " & folderPath, vbCritical
Exit Sub
End If
Set folder = fso.GetFolder(folderPath)
' 初始化当前工作簿
Set wb = ThisWorkbook
' 创建新的目标工作表用于存放合并数据
Set wsMaster = wb.Worksheets.Add(Before:=wb.Worksheets(1))
wsMaster.Name = "Merged_Data_" & Format(Now, "yyyymmdd_hhmmss")
' 初始化目标行的起始位置
targetRow = 1
' 遍历文件夹中的每个Excel文件
For Each file In folder.Files
' 检查文件是否为Excel文件(包括.xls和.xlsx)
If LCase(file.Name) Like LCase(fileExtension) Then
' 打开当前Excel文件
Set wb = app.Workbooks.Open(file.Path)
' 遍历当前工作簿中的每个工作表
For Each ws In wb.Worksheets
' 找到当前工作表的最后一列
lastCol = ws.Cells(1, Columns.Count).End(xlToLeft).Column
' 如果是第一个处理的工作表,复制表头
If targetRow = 1 Then
' 复制表头到目标工作表
ws.Range(ws.Cells(1, 1), ws.Cells(1, lastCol)).Copy _
Destination:=wsMaster.Cells(targetRow, 1)
targetRow = targetRow + 1
End If
' 找到当前工作表的最后一行
lastRow = ws.Cells(Rows.Count, 1).End(xlUp).Row
' 设置数据开始行为第2行(假设第1行为表头)
firstDataRow = 2
' 如果有数据(行数大于表头行)
If lastRow >= firstDataRow Then
' 设置数据范围(从第2行到最后一行,所有列)
Set rng = ws.Range(ws.Cells(firstDataRow, 1), ws.Cells(lastRow, lastCol))
' 复制数据到目标工作表
rng.Copy Destination:=wsMaster.Cells(targetRow, 1)
' 更新目标行号
targetRow = targetRow + rng.Rows.Count
End If
Next ws
' 关闭当前工作簿,不保存更改
wb.Close SaveChanges:=False
End If
Next file
' 自动调整目标工作表列宽
wsMaster.Columns.AutoFit
' 显示完成消息
MsgBox "所有Excel文件的数据已合并到 " & wsMaster.Name, vbInformation
' 清理对象引用
Set wsMaster = Nothing
Set wb = Nothing
Set folder = Nothing
Set fso = Nothing
Set app = Nothing
Exit Sub
ErrorHandler:
' 显示错误信息
MsgBox "发生错误: " & Err.Description, vbCritical
' 清理对象引用
If Not wb Is Nothing Then wb.Close SaveChanges:=False
Set wsMaster = Nothing
Set wb = Nothing
Set folder = Nothing
Set fso = Nothing
Set app = Nothing
End Sub
运行说明
- 将此代码复制到Excel的VBA编辑器中(Alt+F11)。
- 修改代码中的 folderPath 变量为实际文件夹路径(例如 "C:\Data")。
- 确保所有Excel文件(.xls 或 .xlsx)的工作表具有相同的结构(相同的列标题)。
- 运行宏(F5或通过Excel的宏菜单)。
- 合并结果将生成在名为"Merged_Data_日期时间"的新工作表中。
注意事项
- 请确保目标文件夹路径正确且可访问。
- 所有工作表需具有一致的表头结构,以确保合并结果的准确性。
- 建议备份数据以防意外数据丢失。
- 代码会自动关闭处理过的Excel文件,以避免内存问题。
- 如果文件夹中包含其他类型的 .xls* 文件(如 .xlsm),它们也会被处理;如需限制,仅处理 .xls 和 .xlsx,需进一步修改 fileExtension 逻辑。
猜你喜欢
- 2025-08-31 报告数据填写太麻烦?试试这几个自动填充方法,省时又省力
- 2025-08-31 Deepseek+ollama+WPS如何实现本地玩
- 2025-08-31 航母战力的此消彼长:“两鹤”缺席与“约克城”奇迹
- 2025-08-31 “欧洲萨托利”2022防务展的轱辘们(上)——混合动力车亮相
- 2025-08-31 教你提前用上微软最新的 Windows 10X 系统
- 2025-08-31 Excel VBA 技巧:如何批量选中带特定关键字的工作表?
- 2025-05-25 菜籽饼窝料自制秘方!三步搞定野钓爆护神器,鲫鲤草鱼通杀
- 2025-05-25 将DeepSeek接入WPS,只要三步
- 2025-05-25 一文搞懂 VBA 循环结构,附超实用应用方案!
- 2025-05-25 Deepseek嵌入Excel,帮你自动做表格,感觉我要失业了
- 09-04综艺做成这样都上不了热搜?_综艺节目热播原因
- 09-04webRTC中音频相关的netEQ(二):数据结构
- 09-04每日一词“era”_每日一页歌词
- 09-04css 布局简述_简述css布局技术的特点
- 09-049个专业级别的CSS技巧区分了解和精通的鸿沟
- 09-04BeautifulSoup如何将含有data-tag标签的元素提取出来?
- 09-04CSS 中实现动画效果的方法_css动画制作
- 09-045个CSS新功能,简单好用还超省时间
- 最近发表
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- windowsscripthost (69)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (80)
- mysqlany_value (79)
- static函数和普通函数 (84)
- el-date-picker开始日期早于结束日期 (76)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)