[心缘地方]同学录
首页 | 功能说明 | 站长通知 | 最近更新 | 编码查看转换 | 代码下载 | 常见问题及讨论 | 《深入解析ASP核心技术》 | 王小鸭自动发工资条VBA版
登录系统:用户名: 密码: 如果要讨论问题,请先注册。

[备忘]VBA中拼接字符串效率优化

上一篇:[转]mysql导入数据,LOAD DATA LOCAL INFILE
下一篇:[转]在VBA代码中引用Excel工作表中单元格区域的方式小结

添加日期:2009/6/3 12:19:10 快速返回   返回列表 阅读5767次
原来是简单的使用&不停的拼接,16万个字符串的时候,好长时间……

搜索,折腾,结果大概如下:


Dim startIndex As Long
Dim stringBuffer As String
Dim stepString As String
Dim stepLen As Long

startIndex = 1
stringBuffer = Space(20000) '直接占用两万个字符的空间

For i=0 To 10000 '根据需要循环
    stepString =....'我这里是小拼接一下
    stepLen = Len(stepString)
    If startIndex + stepLen >20001 Then
        ....xxx.value = RTrim(stringBuffer) '我这里直接就用了,没有再次拼接。
        StringBuffer = Space(20000)
        startIndex = 1
    End If
    Mid(stringBuffer,startIndex,stepLen) = stepString '替换指定位置
    startIndex = startIndex + stepLen '下标增加
Next
....xxx.value = RTrim(stringBuffer) '最后还有一次,别忘了。


优化后的时间,呵呵,不到10秒。
 

评论 COMMENTS
没有评论 No Comments.

添加评论 Add new comment.
昵称 Name:
评论内容 Comment:
验证码(不区分大小写)
Validation Code:
(not case sensitive)
看不清?点这里换一张!(Change it here!)
 
评论由管理员查看后才能显示。the comment will be showed after it is checked by admin.
CopyRight © 心缘地方 2005-2999. All Rights Reserved