欧非资源网:安全、免费、专业放心的资源下载站! 最新软件|软件分类

您的位置:欧非资源网 > Excel专区 > Excel教程 > excel利用VBA进行多表合并计算一例

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

时间:2018-03-09 10:12作者:admin来源:未知人气:530我要评论(0)

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

   

   

    方法是:将要存放合并数据的工作表命名为“汇总”,删除工作簿中没有合并数据的工作表,各工作表中要合并的数据右侧和下边没有其他数据。然后在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单元格开始的区域合并计算到“汇总”表中

相关阅读 你想学的FILTER函数用法,很全了当Excel体积臃肿,运行卡顿时,我们应该做些什么?带合并单元格的表格,求和计数也不难​Excel筛选条件怎么设置​ExcelA4页面怎么设置​Excel表格A列被隐藏了怎么恢复​Excel图例位于底部怎么设置​Excel图表怎么嵌入单元格​Excel没保存不小心关闭怎么恢复​Excel图表怎么设置X轴Y轴

文章评论
发表评论

热门文章 excel怎么制作表格?制作excel表格的步骤技巧excel 常见的六个排序方法,你必须要学会excel自动换行显示不全怎么办excel 数据透视表 选定区域不能分组 的原因和解决方法

最新文章 你想学的FILTER函数用法,很全了当Excel体积臃肿,运行卡顿时,我们应该做些什么? 带合并单元格的表格,求和计数也不难​Excel筛选条件怎么设置​ExcelA4页面怎么设置​Excel表格A列被隐藏了怎么恢复

人气排行 excel怎么制作表格?制作excel表格的步骤技巧excel 常见的六个排序方法,你必须要学会excel自动换行显示不全怎么办excel 数据透视表 选定区域不能分组 的原因和解决方法Excel高级筛选怎么用 excel高级筛选多个条件(并且、或用法)excel if函数的多个条件使用方法Excel中的快速填充键ctrl+e没反应,不能用是为什么?excel 判断两列数据是否一致的四种方法

盖楼回复X

(您的评论需要经过审核才能显示)