Excel精英培训网

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

[已解决]代码能不能再优化下

[复制链接]
发表于 2014-1-20 23:31 | 显示全部楼层 |阅读模式
本帖最后由 oplkj 于 2014-1-21 10:03 编辑

book1.rar (36.2 KB, 下载次数: 11)
excel精英培训的微信平台,每天都会发送excel学习教程和资料。扫一扫明天就可以收到新教程
发表于 2014-1-20 23:35 | 显示全部楼层
本帖最后由 大灰狼1976 于 2014-1-20 23:37 编辑

刚才给过你的,应该还有更简便的方法吧
  1. Private Sub CommandButton1_Click()
  2. Dim arr, i&, j&, k&, n&, s$, s1$, l&, l1&, x&, y&
  3. arr = [d1].CurrentRegion
  4. n = 1
  5. For x = 16 To 17
  6.   For j = 1 To UBound(arr, 2) - 1
  7.     For k = 1 To 3
  8.       l = 10: l1 = 10
  9.       For i = x - 15 To x
  10.         If i = x - 14 Or i = x - 2 Then n = -1
  11.         l = l + n * Val(Mid(arr(i, j), k, 1))
  12.         n = 1
  13.       Next i
  14.       For i = x + 2 To x + 17
  15.         If i = x + 3 Or i = x + 6 Or i = x + 15 Then n = -1
  16.         l1 = l1 + n * Val(Mid(arr(i, j), k, 1))
  17.         n = 1
  18.       Next i
  19.       s = s & l Mod 10: s1 = s1 & l1 Mod 10
  20.     Next k
  21.     arr(x, j + 1) = s: s = ""
  22.     arr(x + 17, j + 1) = s1: s1 = ""
  23.   Next j
  24. Next x
  25. [d1].Resize(UBound(arr), UBound(arr, 2)) = arr
  26. End Sub
复制代码
回复

使用道具 举报

发表于 2014-1-20 23:50 | 显示全部楼层
又加了一层循环,简化了代码,如果需要扩展区域,只要简单作相应修改就行了.
  1. Private Sub CommandButton1_Click()
  2. Dim arr, i&, j&, k&, n&, s$, s1$, l&, l1&, x&, y&
  3. arr = [d1].CurrentRegion
  4. n = 1
  5. For y = 16 To 34 Step 17
  6.   For x = 1 To 2
  7.     For j = 1 To UBound(arr, 2) - 1
  8.       For k = 1 To 3
  9.         l = 10: l1 = 10
  10.         For i = y + x - 16 To y + x - 1
  11.           If y = 16 Then If i = y + x - 15 Or i = y + x - 3 Then n = -1
  12.           If y = 33 Then If i = y + x - 15 Or i = y + x - 12 Or i = y + x - 3 Then n = -1
  13.           l = l + n * Val(Mid(arr(i, j), k, 1))
  14.           n = 1
  15.         Next i
  16.         s = s & l Mod 10: s1 = s1 & l1 Mod 10
  17.       Next k
  18.       arr(x, j + 1) = s: s = ""
  19.       arr(x + 17, j + 1) = s1: s1 = ""
  20.     Next j
  21.   Next x
  22. Next y
  23. [d70].Resize(UBound(arr), UBound(arr, 2)) = arr
  24. End Sub
复制代码
回复

使用道具 举报

 楼主| 发表于 2014-1-20 23:59 | 显示全部楼层
大灰狼1976 发表于 2014-1-20 23:50
又加了一层循环,简化了代码,如果需要扩展区域,只要简单作相应修改就行了.

没有结果呀
回复

使用道具 举报

发表于 2014-1-21 09:11 | 显示全部楼层
本帖最后由 大灰狼1976 于 2014-1-21 09:24 编辑

忘记把最后一行改回来了:
[d1].Resize(UBound(arr), UBound(arr, 2)) = arr
还是不行,不好意思,我再看看,今天比较忙,可能要晚一点
回复

使用道具 举报

发表于 2014-1-21 09:33 | 显示全部楼层    本楼为最佳答案   
  1. Private Sub CommandButton1_Click()
  2. Dim arr, i&, j&, k&, n&, s$, l&, x&, y&
  3. arr = [d1].CurrentRegion
  4. n = 1
  5. For y = 16 To 34 Step 17
  6.   For x = 1 To 2
  7.     For j = 1 To UBound(arr, 2) - 1
  8.       For k = 1 To 3
  9.         l = 10: l1 = 10
  10.         For i = y + x - 16 To y + x - 1
  11.           If y = 16 Then If i = y + x - 15 Or i = y + x - 3 Then n = -1
  12.           If y = 33 Then If i = y + x - 15 Or i = y + x - 12 Or i = y + x - 3 Then n = -1
  13.           l = l + n * Val(Mid(arr(i, j), k, 1))
  14.           n = 1
  15.         Next i
  16.         s = s & l Mod 10
  17.       Next k
  18.       arr(y + x - 1, j + 1) = s: s = ""
  19.     Next j
  20.   Next x
  21. Next y
  22. [d1].Resize(UBound(arr), UBound(arr, 2)) = arr
  23. End Sub
复制代码
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-27 08:26 , Processed in 0.334413 second(s), 11 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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