我正在编写一个宏,该宏获取ActiveCell
的当前值,并根据选择的情况更改该值。
然而,我无法确定ActiveCell
是否包含通配符字符串。我不确定我的语法是否正确。如何使我的选择情况进行比较?
Select Case ActiveCell.Value
Case ActiveCell.Value Like "*string*"
ActiveCell.Value = "contains string"
End Select
我正在编写一个宏,该宏获取ActiveCell
的当前值,并根据选择的情况更改该值。
然而,我无法确定ActiveCell
是否包含通配符字符串。我不确定我的语法是否正确。如何使我的选择情况进行比较?
Select Case ActiveCell.Value
Case ActiveCell.Value Like "*string*"
ActiveCell.Value = "contains string"
End Select
可以使用通配符。请记住以下两点:首先,字符串比较表达式的结果为布尔数据类型(True/False);其次,根据Select...Case语句的开发人员参考文献,任何Case表达式必须 "隐式可转换" 为与Select Case测试表达式相同的数据类型。为了演示,让我们使用上面原始帖子中的代码。
Select Case ActiveCell.Value '-->ActiveCell.Value is the test expression
Case ActiveCell.Value Like "*string*" '-->(ActiveCell.Value Like "*string*") is the Case expression.
ActiveCell.Value = "contains string"
End Select
如果我们在任何工作表中选择包含字符串值的单元格,然后使用即时窗口使用TypeName()函数测试这两个表达式的数据类型,我们将获得以下结果:
?TypeName(ActiveCell.Value)
String
?TypeName(ActiveCell.Value Like "*string*")
Boolean
正如您所看到的,Select...Case 在这里将无法工作,因为数据类型不是隐式相同的(一个小例外是,如果在任何单元格中运行宏,该单元格包含“True”或“False”的单词值,Excel 会自动转换为布尔值)。
解决方案实际上非常简单。只需将测试表达式更改为True即可。
Select Case True
Case (ActiveCell.Value Like "*string*")
ActiveCell.Value = "contains string"
End Select
这本质上与编写以下内容相同:
If (ActiveCell.Value Like "*string*") = True Then ActiveCell.Value = "contains string"
使用If...Then或Select...Case主要是个人喜好问题。我个人更喜欢Select...Case结构,因为代码的可读性更好,而且还有其他优点(例如能够将每个Case传递给由逗号分隔的表达式列表,而不是使用OR运算符,使代码更加简洁)。
If ActiveCell.Value Like "*string*" Then ActiveCell.Value = "string"
来自于VBA术语表的比较运算符:
一个字符或符号,表示两个或多个值或表达式之间的关系。这些运算符包括小于 (<),小于等于 (<=),大于 (>),大于等于 (>=),不等于 (<>) 和 等于 (=)。另外还有 Is 和 Like 比较运算符。请注意,在 Select Case 语句中不能将 Is 和 Like 用作比较运算符。
Case Is Like
替换Case ActiveCell.Value Like
。 - SeanC