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

VBA从多个Excel文件复制数据

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

需求

如果您有多个Excel文件,并且每个文件都包含一个名为wsData的工作表,您想要从每个文件的wsData工作表中复制数据到同一个wsOutput工作表中,同时保留每个wsData工作表的表头,那么您需要编写一个能够循环遍历文件夹中所有Excel文件,并逐个打开它们以执行复制操作的VBA宏。

以下是一个示例代码,它假设所有的Excel文件都位于一个特定的文件夹中,并且每个文件都有一个名为wsData的工作表。该宏将打开每个文件,复制wsData的表头到wsOutput(如果它是第一个文件,或者如果之前的文件已经复制了表头,则不会重复复制),然后复制数据到wsOutput的下一行。

VBA代码实现

Sub CopyDataFromMultipleFiles()
    Dim folderPath As String
    Dim fileName As String
    Dim wbData As Workbook
    Dim wsData As Worksheet
    Dim wsOutput As Worksheet
    Dim rngHeader As Range
    Dim lastRowOutput As Long
    Dim firstFile As Boolean
      
    ' 设置输出工作簿和输出工作表
    Set wsOutput = ThisWorkbook.Sheets("Output")
      
    ' 清除输出工作表的内容(如果需要)
    wsOutput.Cells.Clear
      
    ' 设置文件夹路径
    folderPath = "F:\practice\vba-demo\data\"
    fileName = Dir(folderPath & "*.xls") ' 假设文件是.xlsx格式
    firstFile = True ' 标记是否为第一个文件,以决定是否复制表头
    
    If fileName = "" Then
        MsgBox "目录:" & folderPath & "下没有找到.xls文件"
        End
    End If
    
      
    ' 循环遍历文件夹中的每个文件
    Do While fileName <> ""
        ' 构建完整的文件路径
        Dim fullFilePath As String
        fullFilePath = folderPath & fileName
          
        ' 打开工作簿
        Set wbData = Workbooks.Open(fullFilePath)
          
        ' 设置wsData工作表
        Set wsData = wbData.Sheets("wsData")
          
        ' 检查是否找到了wsData工作表
        If Not wsData Is Nothing Then
            ' 复制表头到输出工作表(仅当处理第一个文件时)
            If firstFile Then
                Set rngHeader = wsData.Range("A1").CurrentRegion.Rows(1) ' 假设表头在第一行
                rngHeader.Copy Destination:=wsOutput.Range("A1")
                firstFile = False ' 标记已经复制过表头
            End If
              
            ' 找到输出工作表的最后一行
            lastRowOutput = wsOutput.Cells(wsOutput.Rows.Count, "A").End(xlUp).Row + 1
              
            ' 复制数据到输出工作表
            wsData.Range("A2").CurrentRegion.Offset(1, 0).Copy Destination:=wsOutput.Cells(lastRowOutput, 1)
        Else
            MsgBox "在文件 '" & fullFilePath & "' 中未找到名为 'wsData' 的工作表。"
        End If
          
        ' 关闭工作簿,不保存更改
        wbData.Close SaveChanges:=False
          
        ' 获取下一个文件名
        fileName = Dir()
    Loop
      
    ' 提示操作完成
    MsgBox "数据已从多个文件中复制到输出工作表。"
End Sub

在这个宏中,我们首先设置了输出工作簿和输出工作表,并清除了输出工作表的内容(如果需要的话)。然后,我们定义了文件夹路径,并使用Dir函数遍历该文件夹中的所有Excel文件。对于每个文件,我们打开它,检查是否存在名为wsData的工作表,并复制表头和数据到输出工作表。在复制数据之前,我们找到输出工作表的最后一行,以便将数据放在正确的位置。最后,我们关闭工作簿并不保存更改,然后继续处理下一个文件,直到遍历完所有文件。

请注意,这个宏假设所有wsData工作表的表头都在第一行,并且数据区域紧接着表头。如果您的实际情况有所不同,您可能需要调整rngHeader和复制数据范围的代码以适应您的具体情况。此外,确保将文件夹路径更改为包含您Excel文件的实际文件夹路径。

相关推荐

HR必备Excel函数:4个与日期相关的计算函数。

提到日期函数,很多人首先会想到“today”,它可以显示当天的日期,并且每次打开表格时都会自动更新。但是,对于前天、昨天、明天和后天的日期,就不能用yesterday或者tomorrow等这些英文了,...

这篇文章有点长,但可以让你十分钟玩转Excel的时间函数

日期与时间函数——TODAY、NOW、YEAR、MONTH、DAY!如何用WORKDAY函数查询距离某天的第20个工作日是哪一天?如何用NETWORKDAYS函数查询员工工作了多少个工作日?如何用WE...

Excel2020年日历套装,表格设计,农历显示,查阅套打轻松应用

Hello大家好,我是帮帮。今天跟大家分享一组Excel2020年日历套装,表格设计,自带农历控件,查阅套打轻松应用。有个好消息!为了方便大家更快的掌握技巧,寻找捷径。请大家点击文章末尾的“了解更多”...

巧用NETWORKDAYS函数计算两个日期之间工作日的天数

带有日期的单元格是我们日常使用EXCEL的时候经常见到的,有的时候我们需要求出两个日期之间间隔的天数,可以直接用结束日期减去开始日期即可,这是个非常简单的减法公式。不过这个单纯的减法公式会默认去掉开始...

Excel按工作日、休息日进行汇总

1、按周六日/其它时间汇总为了区分一周的周六日和其它时间,可以使用WEEKDAY函数,把WEEKDAY函数的第2个参数指定为2,如WEEKDAY(A3,2),则周一返回1,周二返回2,…,周六返回...

如何计算每月应出勤天数,如有法定假期和调休,如何计算

本文介绍如何计算每月的应出勤天数。第一部分介绍正常双休制下计算应出勤天数;第二部份介绍当月有法定假期和调休的情况下计算应出勤天数。一、计算正常双休制的应出勤天数如下图所示,要求计算各员工2021年3月...

《Excel一键生成工作日历:让会议排期更轻松!》

每当需要安排会议时,总要翻看日历确认工作日,再逐个标注会议时间,既耗时又容易出错。今天教大家用Excel快速生成工作日历表,让会议排期变得简单高效!一、快速生成日历框架创建基础日期:在A1单元格输入月...

如何计算指定日期区间内,有多少工作日和休息日?

大家好,今天咱们要解决的问题是如何计算给定的一段日期内,正常工作日有多少天,放假时间有多少天?比如咱们要计算2025年3月份工作日一共有多少天,又有多少天放假,如下图所示:通过肉眼我们可以数清楚,20...

如何如何在表格中自动突出显示双休日?

现在不少人喜欢用Excel来制作备忘录或安排工作事项。在表格中输入日期后,可以使用条件格式突出显示双休日,避免在休息日安排了工作。具体方法是这样的:第1步:选择要设置条件格式的日期单元格区域;在“开始...

excel函数技巧:networkdays.intl判断节假日

如图,想知道6月的每一天是否是节假日,公式如下:=NETWORKDAYS.INTL(A2,A2,1,$E$2:$E$28)这个函数既可以判断当前日期(一参=二参)是否是周末及工作日(三参、四参)还可得...

仅需3步,让考勤表根据实际休息日,自动地填充颜色

Hello,大家好,之前跟大家分享了我们如何让考勤表根据单休与双休自动的填充颜色,最近有粉丝问到:能不能让考勤表根据实际的休息日自动的填充颜色呢?可以是可以,只不过因为牵扯到假期调休,我们每年的休息日...

5步搞定动态考勤表!标记节假日、调休日?Excel自动变色!

今天教你用「动态考勤表」一招解决所有问题!只需输入月份,自动变色、自动更新节假日,从此告别加班,效率翻倍!动态考勤表的优势:自动变色:节假日、双休日一键标记,颜色分明。一表多用:修改月份即可...

一起用python做个炫酷音乐播放器,想听啥随便搜

前言前段时间写的Python自制一款炫酷音乐播放器,有不少小伙伴私信我,对播放器提了不少改进建议,让我完善播放器的功能。今天音乐播放器2.0版本完成了,大家一起来看看是如何用python自制一款炫酷的...

用Python做个“冰墩墩雪容融”桌面部件(好玩又有趣)

桌面太单调?今天就带大家,一起用Python的PyQt5开发一个有趣的自定义桌面动画挂件,看看实现的动画挂件效果!下面,我们开始介绍这个自定义桌面动画挂件的制作过程。一、核心功能设计实现将动态图gif...

Python串口调试助手源码分享

以下是一个基于Python和PyQt5实现的串口调试助手示例,包含核心功能实现代码:pythonimportsysimportserialfromPyQt5.QtCoreimportQTim...