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

VBA合并同文件夹下所有EXCEL文件工作表同构数据(附代码)

myzbx 2025-09-01 09:52 5 浏览

本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

运行说明

  1. 将此代码复制到Excel的VBA编辑器中(Alt+F11)。
  2. 修改代码中的 folderPath 变量为实际文件夹路径(例如 "C:\Data")。
  3. 确保所有Excel文件(.xls 或 .xlsx)的工作表具有相同的结构(相同的列标题)。
  4. 运行宏(F5或通过Excel的宏菜单)。
  5. 合并结果将生成在名为"Merged_Data_日期时间"的新工作表中。

注意事项

  • 请确保目标文件夹路径正确且可访问。
  • 所有工作表需具有一致的表头结构,以确保合并结果的准确性。
  • 建议备份数据以防意外数据丢失。
  • 代码会自动关闭处理过的Excel文件,以避免内存问题。
  • 如果文件夹中包含其他类型的 .xls* 文件(如 .xlsm),它们也会被处理;如需限制,仅处理 .xls 和 .xlsx,需进一步修改 fileExtension 逻辑。

相关推荐

半导体行业术语缩写词典总结-JKL_半导体词汇缩写表

作为半导体行业新人来说,最痛苦的莫过于各种缩写词术语了,有的缩写词一样但是会有不同的解释。这里作者给大家整理了部分术语词典,后面会按照更新顺序一一分享出来。废话不多说,直接开始,如有遗漏,欢迎大家在评...

JD.com Deepens Push Into Embodied Intelligence With Investment in Sensor Maker PaXiniTech

ToraOne,thesecond-generationmultidimensionaltactilehumanoidrobotdevelopedbyPaXiniTechTMTPOS...

Hong Kong's Consumer Market Becomes New Battleground for Chinese Mainland Internet Giants

AI-generatedimageTMTPOST--StrollthroughthestreetsofHongKongtoday,anditmightfeellikey...

http2解决了哪些问题_简述http2的优点

HTTP/2(最初称为SPDY)是HTTP协议的第二个主要版本,它在HTTP/1.1的基础上进行了重大改进,旨在解决其在性能和效率方面的诸多瓶颈。以下是HTTP/2主要解决的问题:队头阻...

China's economy stays strong and vital amid pressure

Peoplevisitthe4thChina-CEECExpo&InternationalConsumerGoodsFairinNingbo,eastChina's...

JD.com Makes $2.4 Billion Bid for Ceconomy in Bold Push to Build a Global Retail Empire

TMTPOST--JD.comhasunveiledplanstoacquireGermany’sCeconomyAG—theparentofEurope’sleading...

深入剖析 Java 中的装饰器设计模式:原理、应用与实践

在Java软件开发的广阔天地里,设计模式犹如璀璨星辰,照亮我们构建高效、可维护系统的道路。今天,让我们聚焦于其中一颗闪耀的星——装饰器设计模式,深入探究它的奥秘,看看如何利用它为我们的代码赋予...

组合模式应用-适配器模式_适配器组件

写在前面Hello,我是易元,这篇文章是我学习设计模式时的笔记和心得体会。如果其中有错误,欢迎大家留言指正!该部分为各模式组合使用,涉及代码较多,熟能生巧。内容回顾定义适配器模式是一种结构型设计模式,...

OOM (Out Of Memory) 故障排查指南

1.确认OOM类型首先需要确认是哪种类型的OOM:JavaHeapOOM:Java堆内存不足NativeMemoryOOM:本地内存不足MetaspaceOOM:元空间内存不足Contai...

刷完这49题,面试官当场给Offer!Java程序员必备指南

1.问题:如果main方法被声明为private会怎样?答案:能正常编译,但运行的时候会提示”main方法不是public的”。2.问题:Java里的传引用和传值的区别是什么?答案:传引用是指传递的是...

C#编程基础(看这一篇就够了)_c#编程入门与应用

C#及其开发环境简介C#概述C#是一个现代的、通用的、面向对象的编程语言,由微软(Microsoft)开发,经Ecma和ISO核准认可。它由AndersHejlsberg和他的团队在.NET框架开发...

说一下JDK的监控和 线上处理的一些case

一句话总结JDK监控常用工具包括JConsole、VisualVM、JMC等,用于实时查看内存、线程、GC状态。线上常见问题处理:内存泄漏通过heapdump分析对象引用链;频繁GC可调整-Xmx/...

JavaScript深拷贝极简指南:3种方法解决嵌套与循环引用难题

为什么需要深拷贝?首先我们看看浅拷贝,point指向的是同一个地址,这时我们修改obj2.point的属性时,obj1的point属性也会被修改再看看深拷贝,point指向的是不同地址,这时我们修改o...

Java 25 在 JEP 519 中集成了紧凑对象头

作者|ANMBazlurRahman译者|刘雅梦策划|丁晓昀Java25通过JEP519将紧凑对象头作为产品特性进行了集成,在不需要更改任何代码的情况下,为开发人员提供了...

每日一练 Python 面试题(1)_python每日一记

以下是5道Python基本语法相关的面试题,涵盖变量、运算符、数据结构、函数和异常处理等核心概念:1.变量与作用域题目:以下代码的输出是什么?解释原因。x=10deffunc():...