一个复杂的多表汇总问题(表头会变动),请高人指点?
时间:2011-08-06
来源:互联网
问题:
想对月数据进行汇总(同项目 同姓名的就相加)
说明:
1.明细表的个数不确定
2.明细表的 项目都在第2行(从A3开始) 和 姓名 都在第一列(从B2开始)
3.明细表的项目 和 姓名 是可以变化的(这里只是列举了3个月的数据)
(汇总时,黄色区域根据明细表的变化 包含了明细表中的所有对应内容的最大集合--剔除重复,现在的样子就是一个例子)
附件

2011-8-6 18:23, 下载次数: 7
作者: andrewyang 发布时间: 2011-08-06
Sub Macro1()
Dim arr, brr(), sh As Worksheet, i&, j&, m&, n&, d As Object, ds As Object
Set d = CreateObject("scripting.dictionary")
Set ds = CreateObject("scripting.dictionary")
For Each sh In Sheets
If sh.Name <> "汇总" Then
arr = sh.[a1].CurrentRegion
For j = 2 To UBound(arr, 2)
If Not d.Exists(arr(2, j)) Then
n = n + 1
d(arr(2, j)) = n
End If
Next
End If
Next
ReDim brr(1 To 60000, n)
For Each sh In Sheets
If sh.Name <> "汇总" Then
arr = sh.[a1].CurrentRegion
For i = 3 To UBound(arr)
If Not ds.Exists(arr(i, 1)) Then
m = m + 1
ds(arr(i, 1)) = m
brr(m, 0) = arr(i, 1)
For j = 2 To UBound(arr, 2)
brr(m, d(arr(2, j))) = arr(i, j)
Next
Else
For j = 2 To UBound(arr, 2)
brr(ds(arr(i, 1)), d(arr(2, j))) = brr(ds(arr(i, 1)), d(arr(2, j))) + arr(i, j)
Next
End If
Next
End If
Next
ActiveSheet.UsedRange.Offset(2).ClearContents
Range("B2:iv2").ClearContents
[b2].Resize(, n) = d.Keys
[a3].Resize(m, n + 1) = brr
Application.ScreenUpdating = True
End Sub
作者: zhaogang1960 发布时间: 2011-08-06

作者: zhaogang1960 发布时间: 2011-08-06
附件

2011-8-6 19:01, 下载次数: 4
作者: KCFONG 发布时间: 2011-08-06
附件

2011-8-6 19:20, 下载次数: 9
作者: yangrongguan 发布时间: 2011-08-06
附件

2011-8-6 19:55, 下载次数: 6
作者: yaozong 发布时间: 2011-08-06
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28