网站首页 > 文章精选 正文
如图示例:统计各个类别总数,共处理了多少?
源用上一篇字典的应用,处理方法一样的。但上一篇中字典的Item仅为单个数据,此示例中,Item要记录下两个数据,语句写法dic(arr(i, 1)) = Array(arr(i, 2), arr(i, 3));于是碰到重复时,item值求和就变成了数组的累加。
第一种的写法dic(arr(i, 1)) = Array(arr(i, 2) + dic(arr(i, 1))(0), arr(i, 3) + dic(arr(i, 1))(1)) 示例中加有VAL函数,是因为图片中数据是文本型数字。 释义:字典的Item赋值为一维数组,有两个数据,这种情况下的数组都是从 0 标号开始的,dic(arr(i, 1))(0)表示Item第一个数据,字典里存的是之前的数据,arr(i, 2)数组中是现在单元格的数据,两个数据分别相加,然后再组成新的数组赋值给字典。我觉得这写法语句太长,查找到第二种。
第二种语句写法:dic(arr(i, 1)) = Evaluate("{" & Join(dic(arr(i, 1)), ",") & "}+{" & Join(Array(arr(i, 2), arr(i, 3)), ",") & "}") 来源于Excelhome网站,意思:两数组的值对应相加。可能是 Evaluate固定格式要将数组表示成{3,5,7}这样的形式才能运算,语句也很长。
第三种写法:用一个数组变量,用Item赋值给它,将此变量的值分别计算,然后赋值回item。语句:brr=dic(arr(i, 1));brr(0) = brr(0) + arr(i, 2); brr(1) = brr(1) +arr(i, 3) ; dic(arr(i, 1)) = brr; Erase brr (注意brr的清空)。 在Item的数据项较多时,此法可用循环更方便。此法其实就是第一种的引申。
Set dic = CreateObject("scripting.Dictionary")
arr = Range("C2", [E2].End(xlDown))
For i = 1 To UBound(arr)
If dic.Exists(arr(i, 1)) Then
dic(arr(i, 1)) = Array(Val(arr(i, 2)) + dic(arr(i, 1))(0), Val(arr(i, 3)) + dic(arr(i, 1))(1))
Else
dic(arr(i, 1)) = Array(Val(arr(i, 2)), Val(arr(i, 3)))
End If
Next i
[G2].Resize(dic.Count, 1) = WorksheetFunction.Transpose(dic.Keys)
[H2].Resize(dic.Count, 2) = WorksheetFunction.Transpose(WorksheetFunction.Transpose(dic.Items))
这里最后一句释义:dic.Items是一个一维嵌套数组,要两次转置,变成个普通的二维数组。
猜你喜欢
- 2025-04-27 C# - 初识数组 033
- 2025-04-27 LeetCode-448-找到所有数组中消失的数字
- 2025-04-27 「算法」几分钟时间让你彻底学会—时间复杂度
- 2025-04-27 Vlookup一次性查找多个值,4种方法,你更喜欢哪种?
- 2025-04-27 用long类型让我出了次生产事故,写代码还是要小心点
- 2025-04-27 C语言实现从数组中随机选取并返回一个元素
- 2025-04-27 Excel如何运用INDEX+SMALL+IF数组函数进行第几次查找
- 2025-04-27 一式取数!教你如何快准狠地提取单元格里面的数字
- 2025-04-27 怎样的数组在手机号里容易让孩子成绩不稳定呢?
- 2025-04-27 正则表达式学习之替换分组练习
- 最近发表
- 标签列表
-
- newcoder (56)
- 字符串的长度是指 (45)
- drawcontours()参数说明 (60)
- unsignedshortint (59)
- postman并发请求 (47)
- python列表删除 (50)
- 左程云什么水平 (56)
- 计算机网络的拓扑结构是指() (45)
- 稳压管的稳压区是工作在什么区 (45)
- 编程题 (64)
- postgresql默认端口 (66)
- 数据库的概念模型独立于 (48)
- 产生系统死锁的原因可能是由于 (51)
- 数据库中只存放视图的 (62)
- 在vi中退出不保存的命令是 (53)
- 哪个命令可以将普通用户转换成超级用户 (49)
- noscript标签的作用 (48)
- 联合利华网申 (49)
- swagger和postman (46)
- 结构化程序设计主要强调 (53)
- 172.1 (57)
- apipostwebsocket (47)
- 唯品会后台 (61)
- 简历助手 (56)
- offshow (61)