Excel精英培训网

 找回密码
 注册
数据透视表40+个常用小技巧,让你一次学会!
查看: 5528|回复: 9

用VBA进行多表合并计算一例(forward)

[复制链接]
发表于 2011-10-19 20:31 | 显示全部楼层 |阅读模式
在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单元格开始的区域合并计算到“汇总”表中。
    单击右边文件名下载示例文件:VBA多表合并示例.xls
发表于 2011-10-19 23:19 | 显示全部楼层
回复

使用道具 举报

发表于 2011-10-20 12:26 | 显示全部楼层
回复

使用道具 举报

发表于 2011-10-20 12:27 | 显示全部楼层
下载看看!!
回复

使用道具 举报

发表于 2011-10-20 12:27 | 显示全部楼层
好好学习天天向上
回复

使用道具 举报

发表于 2011-10-20 12:28 | 显示全部楼层
看起来就晕
回复

使用道具 举报

发表于 2011-10-20 12:34 | 显示全部楼层
为什么下载不下来
回复

使用道具 举报

 楼主| 发表于 2011-10-20 13:29 | 显示全部楼层
回复 淮南王 的帖子

不需要下载的,没有附件,直接copy就可以了!
回复

使用道具 举报

发表于 2012-1-1 00:46 | 显示全部楼层
好好学习天天向上
回复

使用道具 举报

发表于 2012-5-26 11:25 | 显示全部楼层
支持楼主,想问下,新增工作表后,所有工作表的数据自动合并计算,如何做到?
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|Archiver|Excel精英培训 ( 豫ICP备11015029号 )

GMT+8, 2024-5-22 11:57 , Processed in 0.535091 second(s), 9 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表