Excel:vba实现合并工作表(表头相同)

这个代码应该也适用于一些表头相同的工作表的汇总,只需要修改想要遍历的表,适用于处理大量表头相同的表的合并

这里的汇总合并表 total 是我事先创建的,我觉得比用vba代码创建要容易一下,如果不事先创建汇总表就用下面的代码,在表的部分会报错(在我的主页Excel:vba实现拆分单元格成一字一单元格里面说过这一点,并写有代码)

Sub total()
    Dim totalws As Worksheet
    Dim ws As Worksheet
    Dim colindex As Integer
    Dim lastrow As Long
    Dim lastcol As Long
    Dim wsname As Variant
    Dim currentRow As Long

    ' 设定目标工作表
    Set totalws = ThisWorkbook.Worksheets("total")
    
    '清空表,防止还没合并的时候表里面有数据以及运行一次覆盖就原有数据
    totalws.Cells.Clear
    
    ' 初始化totalws行索引,意思是从totalws的第一行开始粘贴
    currentRow = 1
    
    ' 遍历需要合并的工作表
    For Each wsname In Array("六1", "六2", "六3", "六4")
        '通过工作表的名称获取工作表
        Set ws = Worksheets(wsname)
        
        ' 查找每张表的最后一行和最后一列
        lastrow = ws.Cells(ws.Rows.Count, 1).End(xlUp).Row
        lastcol = ws.Cells(1, Columns.Count).End(xlToLeft).Column
        
        ' 只在第一次循环时复制表头
        If currentRow = 1 Then
            '将表头复制到汇总表的第一行
            ws.Cells(1, 1).Resize(1, lastcol).Copy Destination:=totalws.Cells(currentRow, 1)
            '行数加一,以便后续数据的粘贴到totalws
            currentRow = currentRow + 1
        End If
        
        ' 复制数据,跳过表头
        ws.Cells(2, 1).Resize(lastrow - 1, lastcol).Copy Destination:=totalws.Cells(currentRow, 1)
        '复制完数据之后,totalws表最后一行的行数加一,以便后续数据的粘贴复制
        currentRow = totalws.Cells(totalws.Rows.Count, 1).End(xlUp).Row + 1
    Next wsname

    MsgBox "数据合并完成!"
End Sub
相关推荐
demodeom20 分钟前
Python 操作 读/写 Excel
服务器·python·excel
流形填表4 小时前
word试题转excel(一键转写excel,无格式要求)
word·excel
流形填表4 小时前
word选择题转excel(一键转写,无格式要求)
word·excel
weixin_4271792815 小时前
使用excel统计概率是否符合预期
excel
cuiyaonan20001 天前
SpringBoot 下的Excel文件损坏与内容乱码问题
spring boot·后端·excel
cuisidong19971 天前
excel IF函数用法
excel
云空1 天前
《基于 Excel 和 CSV 文件数据的迁移学习应用》
人工智能·excel·迁移学习
BLOB_1010011 天前
【折腾一上午】Java POI 导出 Excel 自适应列宽行高
java·excel
云表平台1 天前
微软苹果强强联合,Word、Excel、PowerPoint支持苹果设备跨端接力
微软·word·excel
丿似锦2 天前
Excel-多表数据查找匹配(VLOOKUP)
excel