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

VBA从多个Excel文件复制数据

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

需求

如果您有多个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文件的实际文件夹路径。

相关推荐

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可以挖掘出系统最大能处...