Excel精英培训网

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

[已解决]VBA替换函数

[复制链接]
发表于 2013-7-7 13:01 | 显示全部楼层 |阅读模式
本帖最后由 瀚海人 于 2013-7-7 15:28 编辑

表格里面有函数公式,因运算数据量大
我就想用vba替换函数。
完成23万行数据的统计
请教老师帮助用VBA替换函数。拜谢!!!!
最佳答案
2013-7-7 16:54

  1. Sub test()
  2. On Error Resume Next
  3. Dim arr1, arr2, i, j
  4. arr1 = Range("T1:EI3")
  5. arr2 = Range("R9:EI14")
  6. For i = 2 To UBound(arr2)
  7.     For j = 1 To UBound(arr1, 2)
  8.         If InStr(Join(Application.Transpose(Application.WorksheetFunction.Index(arr1, 0, j))), arr2(i, 1)) Then
  9.             arr2(i, j + 2) = "中"
  10.         Else
  11.             arr2(i, j + 2) = Val(arr2(i - 1, j + 2)) + 1
  12.         End If
  13.     Next j
  14. Next i
  15. Range("R9:EI14") = arr2
  16. End Sub
复制代码
Range("R9:EI14")中的14 替换为最后一行数据所在的行号.

统计.rar

12.68 KB, 下载次数: 16

统计.rar

12.68 KB, 下载次数: 9

excel精英培训的微信平台,每天都会发送excel学习教程和资料。扫一扫明天就可以收到新教程
发表于 2013-7-7 14:41 | 显示全部楼层
回复

使用道具 举报

发表于 2013-7-7 14:48 | 显示全部楼层
回复

使用道具 举报

 楼主| 发表于 2013-7-7 15:21 | 显示全部楼层
表格里面有函数公式
我就想用vba替换函数。完成23万行数据的统计
回复

使用道具 举报

发表于 2013-7-7 15:49 | 显示全部楼层
Excel2003不是最多65536行吗?何来23万行?
回复

使用道具 举报

发表于 2013-7-7 16:54 | 显示全部楼层    本楼为最佳答案   

  1. Sub test()
  2. On Error Resume Next
  3. Dim arr1, arr2, i, j
  4. arr1 = Range("T1:EI3")
  5. arr2 = Range("R9:EI14")
  6. For i = 2 To UBound(arr2)
  7.     For j = 1 To UBound(arr1, 2)
  8.         If InStr(Join(Application.Transpose(Application.WorksheetFunction.Index(arr1, 0, j))), arr2(i, 1)) Then
  9.             arr2(i, j + 2) = "中"
  10.         Else
  11.             arr2(i, j + 2) = Val(arr2(i - 1, j + 2)) + 1
  12.         End If
  13.     Next j
  14. Next i
  15. Range("R9:EI14") = arr2
  16. End Sub
复制代码
Range("R9:EI14")中的14 替换为最后一行数据所在的行号.
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-15 23:14 , Processed in 0.252494 second(s), 11 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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