如何提高这段代码速度?
时间:2011-08-05
来源:互联网
一工作表内有很多列中含有公式,而且所有带公式的单元格均设置了背景色(Interior.ColorIndex = 20 ),有时候不小心公式会丢失,为检查公式丢失情况,写了如下代码:
For Each dyg In sheets("xx").UsedRange
If dyg.Interior.ColorIndex = 20 And dyg.HasFormula = False Then
hang = Sheets("AAA").[A65536].End(xlUp).Row + 1
Sheets("AAA").Range("a" & hang) = dyg.Address & "公式丢失!"
End If
Next
以上代码要逐一搜索所有使用单元格,运行速度在11秒左右,如何能缩小搜索范围,即:把For each 语句限定在有公式的背景色范围内?
如果写成:for each dyg in sheets("XX").interior.colorindex=20 语法错误
请赐教,谢谢!
For Each dyg In sheets("xx").UsedRange
If dyg.Interior.ColorIndex = 20 And dyg.HasFormula = False Then
hang = Sheets("AAA").[A65536].End(xlUp).Row + 1
Sheets("AAA").Range("a" & hang) = dyg.Address & "公式丢失!"
End If
Next
以上代码要逐一搜索所有使用单元格,运行速度在11秒左右,如何能缩小搜索范围,即:把For each 语句限定在有公式的背景色范围内?
如果写成:for each dyg in sheets("XX").interior.colorindex=20 语法错误
请赐教,谢谢!
作者: kmgkmg 发布时间: 2011-08-05
顶上来请高手协助
作者: kmgkmg 发布时间: 2011-08-05
For Each dyg In sheets("xx").UsedRange.SpecialCells(xlCellTypeConstants, 23)
If dyg.Interior.ColorIndex = 20 then
试试
If dyg.Interior.ColorIndex = 20 then
试试
作者: livewire 发布时间: 2011-08-05
不行,监察大哥,改成您的写法后,某单元格的公式丢失了也检查不出来
作者: kmgkmg 发布时间: 2011-08-05
相关阅读 更多
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28