ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 11617|回复: 10

如何用vba代码将一列有重复数据的值提取一个出来,并此唯一值对应的字段进行加总?

[复制链接]

TA的精华主题

TA的得分主题

发表于 2016-12-26 15:51 | 显示全部楼层 |阅读模式
本帖最后由 蒋晓丹 于 2016-12-27 16:58 编辑

各位老师好:
    请问怎么才能从用vba代码从一组有重复数据的列中提取一个唯一的值,然后将这个值对应得字段进行加总然后显示出来。

数据样式.png

数据源和想实现的数据样式.rar

69.36 KB, 下载次数: 75

TA的精华主题

TA的得分主题

发表于 2016-12-26 18:18 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
这个是临时使用? 还是代码中间经常需要使用?
若前者: 用数据-删除重复项,是非常的方便, 本人经常复制这1列或2列到 新表中(这样不破坏原表)使用该功能

若是后者,用字典是统计可以了
for i=1 to 100
if dc.exists(xx)=false then
  dc(xx)=""
  msum=msum+yy
end if
next

TA的精华主题

TA的得分主题

发表于 2016-12-26 20:12 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2016-12-27 14:39 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
哪列有重复的?汇总哪列?

TA的精华主题

TA的得分主题

 楼主| 发表于 2016-12-27 16:59 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
kszcs 发表于 2016-12-27 14:39
哪列有重复的?汇总哪列?

我重新把想实现的结果做成了图示,请您再帮我看看,谢谢哈!

TA的精华主题

TA的得分主题

 楼主| 发表于 2016-12-27 17:00 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
jsgj2023 发表于 2016-12-26 20:12
楼主连具体说明都没给?

我重新把具体说明做成了图示,请您再帮忙看看,谢谢。

TA的精华主题

TA的得分主题

 楼主| 发表于 2016-12-27 17:02 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
smhf_6 发表于 2016-12-26 18:18
这个是临时使用? 还是代码中间经常需要使用?
若前者: 用数据-删除重复项,是非常的方便, 本人经常复制 ...

是想做成一个模板,这个表是审计底稿,之前全部是用函数计算的,由于数据量很大,所以每次运行都特别慢,所以想用vba进行改进,我用字典试了,总是出现bug,自己也没调明白。

TA的精华主题

TA的得分主题

发表于 2016-12-28 18:27 | 显示全部楼层
Sub fjsgfh()
Dim i, ir, m, arr, brr(), tt
Dim dc As Object
Set dc = CreateObject("scripting.dictionary")
tt = Timer
ir = Range("a1").End(xlDown).Row
arr = Range("a2:l" & ir + 1)
For i = 1 To ir - 1
   If arr(i, 3) = arr(i + 1, 3) Then
        If dc.exists(arr(i, 3)) = False Then
        dc(arr(i, 3)) = ""
        m = m + 1
        ReDim Preserve brr(1 To 11, 1 To m)
        brr(1, m) = arr(i, 1) & arr(i, 2)
        brr(2, m) = arr(i, 3)
        brr(3, m) = arr(i, 4)
        brr(4, m) = arr(i, 5)
        brr(5, m) = arr(i, 6)
        brr(6, m) = arr(i, 7)
        brr(7, m) = arr(i, 8)
        brr(8, m) = arr(i, 9)
        Else
        brr(7, m) = brr(7, m) + arr(i, 8)
        brr(8, m) = brr(8, m) + arr(i, 9)
        End If
   Else
        If dc.exists(arr(i, 3)) = False Then
        m = m + 1
        ReDim Preserve brr(1 To 11, 1 To m)
        brr(1, m) = arr(i, 1) & arr(i, 2) & "-" & arr(i, 1) & arr(i, 2)
        brr(2, m) = arr(i, 3)
        brr(3, m) = arr(i, 4)
        brr(4, m) = arr(i, 5)
        brr(5, m) = arr(i, 6)
        brr(6, m) = arr(i, 7)
        brr(7, m) = arr(i, 8)
        brr(8, m) = arr(i, 9)
        brr(9, m) = arr(i, 10)
        brr(10, m) = arr(i, 11)
        brr(11, m) = arr(i, 12)
        Else
        brr(1, m) = brr(1, m) & "-" & arr(i, 1) & arr(i, 2)
        brr(7, m) = brr(7, m) + arr(i, 8)
        brr(8, m) = brr(8, m) + arr(i, 9)
        brr(9, m) = arr(i, 10)
        brr(10, m) = arr(i, 11)
        brr(11, m) = arr(i, 12)
        End If
   End If
Next
ir = Sheet1.Range("a100000").End(xlUp).Row
If ir > 2 Then
Sheet1.Range("a2:k" & ir).ClearContents
End If
   Sheet1.Range("a2").Resize(m, 11) = Application.WorksheetFunction.Transpose(brr)
   MsgBox ("统计完成用时:" & Timer - tt & "秒")
   Set dc = Nothing
End Sub

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2016-12-28 18:33 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
楼主最后做出的模板,与开始说的完全是两回事,虽然代码中仍用到了字典,但使用的含义与原先的回答也就不同了。
另外,由于每个编号下数量是不确定的,除非做两次循环,先统计每个编号的数量,但现在没有这样做。
楼主必须先按编号-日期排序,否则结果也是错的
代码,是通过数组循环处理的,没有什么新鲜的内容。

数据源和想实现的数据样式.7z

92.69 KB, 下载次数: 130

TA的精华主题

TA的得分主题

发表于 2016-12-28 18:39 | 显示全部楼层
不过,循环2次其实也不方便,虽然统计了每个编号的总数量,还要考虑每个编号的最后日期,因为每个编号的最后日期并不相同,所以,想想还是排序吧,排序正确后,就可以直接判断了。
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-11-24 09:24 , Processed in 0.040372 second(s), 15 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

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