Excel精英培训网

 找回密码
 注册
数据透视表40+个常用小技巧,让你一次学会!
查看: 3117|回复: 2

[已解决]修改代码

[复制链接]
发表于 2014-6-7 14:16 | 显示全部楼层 |阅读模式
以下文件中的代码运行速度不够理想,那位大师能修改下代码谢谢
最佳答案
2014-6-7 16:22
本帖最后由 大灰狼1976 于 2014-6-7 16:24 编辑

结果输出在K列
  1. Sub bbb()
  2. t = Timer
  3. Dim arr, arr1, i&, d As Object, d1 As Object, da As Date
  4. da = Sheets(4).[a2]
  5. Set d = CreateObject("scripting.dictionary")
  6. Set d1 = CreateObject("scripting.dictionary")
  7. arr = Sheets(4).Range("a4:b" & Sheets(4).[a65536].End(3).Row)
  8. ReDim arr1(1 To UBound(arr), 1 To 1)
  9. For i = 1 To UBound(arr)
  10.   d(arr(i, 1)) = Val(arr(i, 2))
  11.   d1(arr(i, 1)) = i
  12. Next i
  13. arr = Sheets(2).[a1].CurrentRegion
  14. For i = UBound(arr) To 2 Step -1
  15.   If arr(i, 2) <= da And arr(i, 2) >= da - d(arr(i, 1)) Then arr1(d1(arr(i, 1)), 1) = arr1(d1(arr(i, 1)), 1) + arr(i, 3)
  16. Next i
  17. Sheets(4).[k4].Resize(UBound(arr1)) = arr1
  18. MsgBox Timer - t
  19. End Sub
复制代码

应收款统计.rar

25.41 KB, 下载次数: 7

发表于 2014-6-7 16:22 | 显示全部楼层    本楼为最佳答案   
本帖最后由 大灰狼1976 于 2014-6-7 16:24 编辑

结果输出在K列
  1. Sub bbb()
  2. t = Timer
  3. Dim arr, arr1, i&, d As Object, d1 As Object, da As Date
  4. da = Sheets(4).[a2]
  5. Set d = CreateObject("scripting.dictionary")
  6. Set d1 = CreateObject("scripting.dictionary")
  7. arr = Sheets(4).Range("a4:b" & Sheets(4).[a65536].End(3).Row)
  8. ReDim arr1(1 To UBound(arr), 1 To 1)
  9. For i = 1 To UBound(arr)
  10.   d(arr(i, 1)) = Val(arr(i, 2))
  11.   d1(arr(i, 1)) = i
  12. Next i
  13. arr = Sheets(2).[a1].CurrentRegion
  14. For i = UBound(arr) To 2 Step -1
  15.   If arr(i, 2) <= da And arr(i, 2) >= da - d(arr(i, 1)) Then arr1(d1(arr(i, 1)), 1) = arr1(d1(arr(i, 1)), 1) + arr(i, 3)
  16. Next i
  17. Sheets(4).[k4].Resize(UBound(arr1)) = arr1
  18. MsgBox Timer - t
  19. End Sub
复制代码

应收款统计.zip

30.41 KB, 下载次数: 2

回复

使用道具 举报

发表于 2014-6-7 16:40 | 显示全部楼层
大灰狼用的是字典,咱用的是数组:

应收款统计.zip (28.39 KB, 下载次数: 4)
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|Archiver|Excel精英培训 ( 豫ICP备11015029号 )

GMT+8, 2024-4-19 22:03 , Processed in 0.283004 second(s), 11 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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