ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 1434|回复: 3

[讨论] 这段代码可以用提速吗

[复制链接]

TA的精华主题

TA的得分主题

发表于 2009-6-18 14:26 | 显示全部楼层 |阅读模式
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
这段代码可以用提速吗?详见附件,目的是把“.0123456789()+-*/^%”之外及“[]”和“{}”的字符分开上色。
Public sSize As Byte, zSize As Byte
Public Sub BZ1(Rng As Range)
  Application.ScreenUpdating = False
  Application.Calculation = xlCalculationManual
  If sSize = 0 Then sSize = 10
  If zSize = 0 Then zSize = 7
  Dim XX1(100), XX2(100), XX3(100), XX4(100)
  With Rng.Font
    .Size = sSize
    .ColorIndex = 1
    End With
  For Each S In Rng
    ii = 0
    For i = 1 To Len(S)
      Select Case Mid(S, i, 1)
      Case "{"
        ii = ii + 1: i0 = i: XX1(ii) = i
        Do Until Mid(S, i, 1) = "}"
          i = i + 1: If i > Len(S) Then Exit Do
          Loop
        XX2(ii) = i - i0 + 1: XX3(ii) = 3: XX4(ii) = sSize
      Case "0" To "9", "+", "-", "*", "/", "(", ")", "^", ".", "(", ")"
      Case "["
        ii = ii + 1: i0 = i: XX1(ii) = i
        Do Until Mid(S, i, 1) = "]"
          i = i + 1: If i > Len(S) Then Exit Do
          Loop
        XX2(ii) = i - i0 + 1: XX3(ii) = 32: XX4(ii) = zSize
      Case Else
        ii = ii + 1: i0 = i: XX1(ii) = i
        Do While InStr(".0123456789+-*/%^()()", Mid(S, i, 1))
          i = i + 1: XX1(ii) = i
          Loop
        XX2(ii) = i - i0 + 1: XX3(ii) = 32: XX4(ii) = zSize
      End Select
    Next i
    For k = 1 To ii
      With Cells(S.Row, S.Column).Characters(Start:=XX1(k), Length:=XX2(k)).Font
        .ColorIndex = XX3(k)
        .Size = XX4(k)
        End With
      Next k
  Next S
  Application.ScreenUpdating = True
  Application.Calculation = xlCalculationAutomatic
End Sub

[ 本帖最后由 Zamyi 于 2009-6-26 22:07 编辑 ]

Test.rar

23.31 KB, 下载次数: 31

TA的精华主题

TA的得分主题

发表于 2009-6-18 15:36 | 显示全部楼层
涉及到Characters,只能逐单元格逐字节操作,正则没办法.

TA的精华主题

TA的得分主题

 楼主| 发表于 2009-6-19 09:08 | 显示全部楼层
原帖由 extyg 于 2009-6-18 15:36 发表
涉及到Characters,只能逐单元格逐字节操作,正则没办法.

说得也对,下面这一部分用掉整个时间的90%。这部分真的不能提速吗?
For k = 1 To ii
      With Cells(S.Row, S.Column).Characters(Start:=XX1(k), Length:=XX2(k)).Font
        .ColorIndex = XX3(k)
        .Size = XX4(k)
        End With
      Next k

TA的精华主题

TA的得分主题

 楼主| 发表于 2009-6-19 16:24 | 显示全部楼层
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-12-23 04:14 , Processed in 0.042881 second(s), 11 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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