EXCEL VBA终极提速,超级公式,算法优化

1,简化公式,200个字变成10个字

有很多公式写的很长,看不懂很难维护,如果改成VBA代码,简化成一个超级函数,方便维护,还可以给多个工程共用,实现模块化开发

2,计算提速。有些vba运算很慢,需要几分钟到几小时,用好的方法,运行速度可以减到1分钟以内甚至10秒以内。

这2天做了一个3万个左右的订单表和产品销售统计的算法。

原来的主人,运行后就卡死了,后面按10个产品去查找订单,需要1秒左右,那3万个产品就要3000秒,差不多一个小时才能完成。

后面采用了字典的方法代替每个单元格去循环对比,速度提高了100倍,只需要30秒左右。

再后来发现写入3万行2列数据也要10秒左右,采用变量绑定直接写入,只需要60毫秒。

经过终极优化,最终只需要200毫秒就完成了全部运算。

速度又提高了150倍,比最初的算法速度提高了1.5万倍。

如果还能采用多线程进行计算,估计还能提高不少。不过总体时间只有0.2秒了,没必要再折腾了。他的想法是30秒以内就很好了。

2.3万个数据转成字典Key,不引用Dictionary,用时:5281毫秒

引用的话只要39毫秒,快了135倍

写入6.3万个excel单元格用时=2304毫秒

直接用数组方式改变一批单元格只要57毫秒,快了39倍

vbnet 复制代码
2.86万个订单,查找的产品2.29万个
不用字典,纯循环查找用时17.3秒
字典生成39毫秒,查找用时85毫秒

================

V12-引用Dictionary 字典法强制声明最快

数据行数=28627,条件末行=22943

条件转字典用时:39毫秒

取产品+数量+金额 数据用时:16毫秒

提取所有数据用时=67毫秒
统计用时=85毫秒

写入单元格(超级法)用时=57毫秒

【借方V12】 >用时209毫秒,约0.003分钟


'v12不引用Dictionary 字典法,后期绑定,不声明从0.2秒变成了12秒

条件转字典用时:5281毫秒

取产品+数量+金额 数据用时:20毫秒

提取所有数据用时=5310毫秒

统计用时=6588毫秒

写入单元格(超级法)用时=59毫秒

借方V12 >用时11957毫秒

============== 纯数组方式循环几万*几万次的查找,用时17秒,最古老的方法,慢

条件转字典用时:0毫秒

取产品+数量+金额 数据用时:16毫秒

提取所有数据用时=29毫秒

统计用时=17252毫秒

写入单元格(超级法)用时=62毫秒

【借方V12】 >用时17343毫秒,约0.289分钟

相关推荐
wtsolutions4 小时前
Excel-to-JSON插件专业版功能详解:让Excel数据转换更灵活
json·excel·excel-to-json·wtsolutions·专业版
梦幻通灵5 小时前
Excel分组计算求和的两种实现方案
前端·excel
莫负初7 小时前
Excel使用VBA批量计算指定列的中位数和标准差并筛选指定列数据
数据分析·自动化·excel·vba·方差·标准差
杜子腾dd19 小时前
17.Excel:实用的 VBA 自动化程序
数据分析·自动化·excel
是孑然呀1 天前
【小记】excel vlookup一对多匹配
excel
chaodaibing1 天前
pandas读取pymysql和解析excel的一系列问题(版本不匹配)
excel·pandas
沉到海底去吧Go2 天前
【身份证识别表格】批量识别身份证扫描件或照片保存为Excel表格,怎么大批量将身份证图片转为excel表格?基于WPF和腾讯OCR的识别方案
ocr·wpf·excel·身份证识别表格·批量扫描件身份证转表格·图片识别表格·图片识别excel表格
a GISer doctor2 天前
EXCEL中嵌入其他表格等文件
excel
yngsqq2 天前
CAD属性图框值与Excel联动(CAD块属性导出Excel、excel更新CAD块属性)——CAD c#二次开发
excel
帆张芳显2 天前
前端EXCEL插件,智表ZCELL产品V3.0 版本发布,底层采用canvas全部重构,功能大幅扩展,性能极致提升,满足千万级单元格加载
前端·重构·excel·jquery·插件·智表