并肩作战的好兄弟实现快速汇总:字典 + 数组

2024-02-06 06:50

本文主要是介绍并肩作战的好兄弟实现快速汇总:字典 + 数组,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

VBA开发者经常讨论的一个话题就是:字典和数组哪个效率更高?使得很多VBA初学者懵懂的认为,这两者非此即彼,水火不容。其实很多应用场景中,它们是并肩作战的好兄弟。

实例需求

已有生产排程数据如下所示。

需要整理为如下格式。

数据合并的要点有三个:

  • 料号和机种号为统计的关键字段
  • 未交数量求和
  • 交期汇总,包含时间和数量

示例代码

Sub LoadData()Dim aData, aRes(), lst, iRow, iCol, iKeyCol, DicConst COLUMNS_QTY = 21With Sheets("交货排程")iKeyCol = 5lst = .Cells(.Rows.Count, iKeyCol).End(xlUp).RowaData = .Cells(2, 1).Resize(lst, COLUMNS_QTY).ValueEnd WithSet Dic = CreateObject("Scripting.Dictionary")For iRow = 3 To UBound(aData, 1)skey = aData(iRow, 5) & "|" & aData(iRow, 6)If Len(skey) > 1 ThenIf Dic.exists(skey) ThenDic(skey) = Array(Val(aData(iRow, 9)) + Dic(skey)(0), Dic(skey)(1))ElseDic(skey) = Array(Val(aData(iRow, 9)), "")End IfFor iCol = 11 To UBound(aData, 2)If Val(aData(iRow, iCol)) > 0 Thensdate = VBA.Replace(Format(aData(2, iCol), "m-d"), "-", "/")Debug.Print Dic(skey)(1) & "," & sdate & "*" & aData(iRow, iCol)Dic(skey) = Array(Dic(skey)(0), Dic(skey)(1) & "," & sdate & "*" & aData(iRow, iCol))End IfNext iColEnd IfNext iRowReDim aRes(1 To Dic.Count, 1 To 4)n = 1For Each d In Dic.keysakey = Split(d, "|")aRes(n, 1) = akey(0)aRes(n, 2) = akey(1)aRes(n, 3) = Dic(d)(0)aRes(n, 4) = Mid(Dic(d)(1), 2)n = n + 1Next' 结果数组aRes回写到工作表中With Sheets("结果").Range("2:10000").ClearContents.Cells(2, 1).Resize(Dic.Count, 4).Value = aRes.Range("a1").CurrentRegion.Borders.LineStyle = xlContinuousEnd WithSet Dic = Nothing
End Sub
代码解析

对于需要进行排重统计的应用,使用数组就可以实现,对于每个数据行都需要循环对比数组的全部元素,然而字典对象元素具有唯一性,因此对于排重统计有着独到的优势。
对于每个关键字段组合,需要保存的信息有:两个关键字段,数量和相应的日期,此时数组就可以方便保存多个数据。因此使用字典和数组组合的双剑合璧,功力无敌!
将工作表数据加载到数组的代码,不需要多讲。

aData = .Cells(2, 1).Resize(lst, COLUMNS_QTY).Value

将关键字段进行组合,确定字典的键值。

skey = aData(iRow, 5) & "|" & aData(iRow, 6)

下面代码将一个 1 x 2的数组保存在字典对象中,如果skey是一个新的键值,那么将未交数量aData(iRow, 9)做为数组第一个元素,第二元素暂时留空。
如果skey是一个在字典中已经存在的键值,那么Val(aData(iRow, 9)) + Dic(skey)(0)将未交数量进行累加,并保留已有的交期信息Val(aData(iRow, 9)) + Dic(skey)(0)

If Dic.exists(skey) ThenDic(skey) = Array(Val(aData(iRow, 9)) + Dic(skey)(0), Dic(skey)(1))
ElseDic(skey) = Array(Val(aData(iRow, 9)), "")
End If

与此类似,下面代码将汇总交期信息。注意更新字典对象的数组元素时,只能全部重新赋值,而不能使用Dic(skey)(0)="xxx"的形式

For iCol = 11 To UBound(aData, 2)If Val(aData(iRow, iCol)) > 0 Thensdate = VBA.Replace(Format(aData(2, iCol), "m-d"), "-", "/")Debug.Print Dic(skey)(1) & "," & sdate & "*" & aData(iRow, iCol)Dic(skey) = Array(Dic(skey)(0), Dic(skey)(1) & "," & sdate & "*" & aData(iRow, iCol))End If
Next iCol

对于字典中保存的数组元素,无法直接回写到工作表中,因此需要先构建回写的二维数组。Mid(Dic(d)(1), 2)用于去掉交期信息中的第一个逗号。

    For Each d In Dic.keysakey = Split(d, "|")aRes(n, 1) = akey(0)aRes(n, 2) = akey(1)aRes(n, 3) = Dic(d)(0)aRes(n, 4) = Mid(Dic(d)(1), 2)n = n + 1Next

后记

对于这个实例,只用数组可以实现吗?肯定可以实现,而且在数据量不大的情况下,效率差距也不大。不用保存数组的字典对象,而使用字典对象嵌套也可以实现。条条大路通罗马,希望大家能够灵活运用字典和数组组合。

这篇关于并肩作战的好兄弟实现快速汇总:字典 + 数组的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/683477

相关文章

Flutter实现文字镂空效果的详细步骤

《Flutter实现文字镂空效果的详细步骤》:本文主要介绍如何使用Flutter实现文字镂空效果,包括创建基础应用结构、实现自定义绘制器、构建UI界面以及实现颜色选择按钮等步骤,并详细解析了混合模... 目录引言实现原理开始实现步骤1:创建基础应用结构步骤2:创建主屏幕步骤3:实现自定义绘制器步骤4:构建U

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

Android实现定时任务的几种方式汇总(附源码)

《Android实现定时任务的几种方式汇总(附源码)》在Android应用中,定时任务(ScheduledTask)的需求几乎无处不在:从定时刷新数据、定时备份、定时推送通知,到夜间静默下载、循环执行... 目录一、项目介绍1. 背景与意义二、相关基础知识与系统约束三、方案一:Handler.postDel

Pandas中统计汇总可视化函数plot()的使用

《Pandas中统计汇总可视化函数plot()的使用》Pandas提供了许多强大的数据处理和分析功能,其中plot()函数就是其可视化功能的一个重要组成部分,本文主要介绍了Pandas中统计汇总可视化... 目录一、plot()函数简介二、plot()函数的基本用法三、plot()函数的参数详解四、使用pl

一文教你Python如何快速精准抓取网页数据

《一文教你Python如何快速精准抓取网页数据》这篇文章主要为大家详细介绍了如何利用Python实现快速精准抓取网页数据,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录1. 准备工作2. 基础爬虫实现3. 高级功能扩展3.1 抓取文章详情3.2 保存数据到文件4. 完整示例

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B

Python位移操作和位运算的实现示例

《Python位移操作和位运算的实现示例》本文主要介绍了Python位移操作和位运算的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 位移操作1.1 左移操作 (<<)1.2 右移操作 (>>)注意事项:2. 位运算2.1