excel利用VBA进行多表合并计算一例

时间:2022-06-28 18:26:18 

在Excel中,用数据透视表可以轻松进行多个区域的数据合并计算。但当区域较多时,要在数据透视表向导中多次选择区域,稍显繁琐。如果需要合并的工作表较多,可以用下面的VBA代码来快速合并数据。区域的大小可以不同,各行或列的品种可以重复,但要求工作簿中各工作表中的数据存放在相同的位置。如下图为工作簿中某两个工作表中的数据,区域的起始位置都是E5单元格:

    excel利用VBA进行多表合并计算一例

    excel利用VBA进行多表合并计算一例

    方法是:将要存放合并数据的工作表命名为“汇总”,删除工作簿中没有合并数据的工作表,各工作表中要合并的数据右侧和下边没有其他数据。然后在VBA编辑器中运行下面的代码:

Sub Summary()
    Worksheets("汇总").[e5].CurrentRegion.ClearContents
    On Error Resume Next
   
    Dim sh As Worksheet
    For Each sh In ActiveWorkbook.Sheets
        If sh.Name <> "汇总" Then
            With sh
                '获取工作表中数据区域的行数
                i = .[e65536].End(xlUp).Row
                '获取工作表中数据区域的列数
                j = .[iv5].End(xlToLeft).Column
                '将各工作表区域按R1C1样式存入tempstr字符串中,各区域之间用","隔开
                tempstr = tempstr & "'" & sh.Name & "'!R5C5:R" & i & "C" & j & ","
            End With
        End If
    Next
    '清除tempstr字符串中最后一个","
    tempstr = Left$(tempstr, Len(tempstr) - 1)
    '将tempstr字符串中的各区域名存入一维数组arr中
    arr = Split(tempstr, ",")
   
    '将各个区域的数据合并计算到"汇总"表
    Worksheets("汇总").[e5].Consolidate arr, xlSum, True, True
    Worksheets("汇总").[e5] = Sheet1.[e5]
End Sub

    上述代码将工作簿中除“汇总”表以外的所有工作表中从E5单元格开始的区域合并计算到“汇总”表中

标签:excel,利用,VBA,进行,多表,合并,计算,一例,在
0
投稿

猜你喜欢

  • 苹果A15处理器怎么样?相较于A14有多大提升?

    2023-08-20 13:19:42
  • excel如何取消合并后上万条空白单元格填充

    2022-08-28 12:16:29
  • Win10 1909怎么以管理员身份运行PowerShell?以管理员身份运行PowerShell方法简述

    2023-11-13 03:48:50
  • 在Excel中给框选的单元格添加颜色看不到网格线的解决方法

    2023-01-19 16:51:53
  • Win10系统时间无法修改怎么办?Win10系统时间无法修改的解决方法

    2023-11-12 09:04:28
  • excel表格输入值非法的解决教程

    2022-08-06 11:03:43
  • Excel表格向上,中,向下取整函数

    2022-04-06 07:26:17
  • 如何关闭Word的审阅修订显示功能 word审阅修订显示功能如何关闭

    2022-06-11 07:58:59
  • win10电脑显存怎么看?win10电脑查看显存的操作方法

    2023-09-24 10:01:58
  • 在Word2010中取消显示Office剪贴板图标

    2023-03-28 00:18:16
  • 如何在Word2010公式中添加希腊字母符号

    2022-04-10 20:17:58
  • word 绘图工具在哪 word 添加绘图工具的方法

    2023-09-23 08:34:12
  • 怎么解决Word2003文档打不开的问题

    2022-03-14 16:07:34
  • Word 如何设置文档中表格的样式

    2023-05-15 16:40:00
  • 3种方法来用Excel制作发票

    2022-01-29 21:58:08
  • WORD中怎样设置字体长宽

    2023-11-29 18:58:44
  • 2021最新office365激活码推荐

    2023-05-31 10:56:11
  • Excel中的INDEX和MATCH函数语法的使用教程

    2023-10-25 18:39:26
  • excel表格怎么用函数进行区间统计

    2023-05-06 06:26:18
  • Win10电脑无故卡死怎么解决?Win10电脑无故卡死怎么解决方法

    2023-11-23 10:17:11
  • asp之家 电脑教程 m.aspxhome.com