我需要使用iif()
对于我检查和分配值的情况,例如:
Range("A1").Value = IIf(IsNull(Range("A2").Value), MsgBox("1"), MsgBox("2"))
我真的对此感到困惑:该行正在执行两者MsgBox
es.我只需要执行其中之一,具体取决于条件是否为真/假。
我尝试使用if
条件,但它会导致错误:“编译错误:预期:表达式”
请帮忙。谢谢。
The IIf 的 VBA 文档表明无论其输出如何,它都会执行 True 和 False 条件。
您需要类似于以下的代码:
Dim Result as Integer
If IsNull(Range("A2").Value) Then
Result = MsgBox("1")
Else
Result = MsgBox("2")
End If
Range("A1").Value = Result
或者,如果您正在寻找单行:
Range("A1").Value = MsgBox(IIf(IsNull(Range("A2").Value), "1", "2"))
虽然这不允许你改变其他MsgBox
参数就像 if 块一样简单。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)