ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

EH搜索     
EH云课堂-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 Excel Home精品图文教程库
Excel不给力? 何不试试FoxTable! Excel 2016函数公式学习大典 EH云课堂直播课程免费学 打造核心竞争力的职场宝典
300集Office 2010微视频教程 Tableau-数据可视化工具 精品推荐-800套精选PPT模板,点击获取 ExcelHome出品 - VBA代码宝免费下载
你的Excel 2010实战技巧学习锦囊 欲罢不能, 过目难忘的 Office 新界面 Excel VBA经典代码实践指南
查看: 181|回复: 3

VBA 赋值运算速度太慢 请帮忙优化附件代码~谢谢

[复制链接]

TA的精华主题

TA的得分主题

发表于 2019-12-18 10:13 | 显示全部楼层 |阅读模式
附件只是简化的模型,实际的模型大小有100M+。 当Count = 1000+的时候,每个点的运算速度呈边际递减,最大的一个模型需要跑40小时,共有20个这样的模型,因此想请大家帮忙优化下VBA代码,提高速度。

VBA优化.zip

78.02 KB, 下载次数: 6

TA的精华主题

TA的得分主题

发表于 2019-12-18 10:45 | 显示全部楼层
大概看了下  J 循环没用,可以取消,50次循环的不影响什么速度

TA的精华主题

TA的得分主题

 楼主| 发表于 2019-12-18 10:52 | 显示全部楼层
Jaofuan 发表于 2019-12-18 10:45
大概看了下  J 循环没用,可以取消,50次循环的不影响什么速度

J 循环是肯定有用的,应该是我的简化模型不够严谨。实际的i循环有5000+,j循环有20+,output也有10多个,当模型100M的时候,就很慢了。能不能只针对以下几行进行优化,应该是赋值粘贴导致速度慢。多谢~

Sheets("T1").Range("A" & 1 + i & ":B" & 1 + i).Value = Sheets("Results").Range("F2:G2").Value
Sheets("T3").Range("A" & 1 + i & ":B" & 1 + i).Value = Sheets("Results").Range("F2:G2").Value
Sheets("T5").Range("A" & 1 + i & ":B" & 1 + i).Value = Sheets("Results").Range("F2:G2").Value

Sheets("T1").Range("C1").Offset(i, 0) = Sheets("Results").Range("H6").Value
Sheets("T3").Range("C1").Offset(i, 0) = Sheets("Results").Range("H8").Value
Sheets("T5").Range("C1").Offset(i, 0) = Sheets("Results").Range("H10").Value
Sheets("T1").Range("D1").Offset(i, 0) = Sheets("Results").Range("J6").Value
Sheets("T3").Range("D1").Offset(i, 0) = Sheets("Results").Range("J8").Value
Sheets("T5").Range("D1").Offset(i, 0) = Sheets("Results").Range("J10").Value

TA的精华主题

TA的得分主题

发表于 2019-12-18 11:29 | 显示全部楼层
大英帝国红领巾 发表于 2019-12-18 10:52
J 循环是肯定有用的,应该是我的简化模型不够严谨。实际的i循环有5000+,j循环有20+,output也有10多个, ...

本来想给你改成数组的,结果一看全是公式套用,我对公式不熟悉,另等高人吧
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

关注官方微信,每天学会一个新技能

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

GMT+8, 2020-2-17 06:26 , Processed in 0.429348 second(s), 16 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2020 Wooffice Inc.

   

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

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

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