如何从函数返回布尔值?

时间:2020-07-18 22:09:32

标签: excel vba function boolean parameter-passing

尝试编写一些错误检查代码。到目前为止,我所有的代码都是一个巨大的子过程。

我在我的工作表中选择了单元格A1,该单元格内部有Test1。然后我运行MainProgramCode宏。

我得到的结果:
函数调用前为False
您从第1列中选择了数据
函数调用后为假

OkToProceed = True之后我有MsgBox "You selected data from column 1"。但是在函数执行完后,MainProgramCode中的OkToProceed变量仍然为False?

Function Check_User_Select_Range_Column(OkToProceed As Boolean)
If Selection.Column = 1 Then
    MsgBox "You selected data from column 1"
    OkToProceed = True
Else
    MsgBox "You did not select data from column 1, please try again."
    OkToProceed = False
End If
End Function


Sub MainProgramCode()
Dim OkToProceed As Boolean

'Do some error checking
MsgBox OkToProceed & " Before Function call "
OkToProceed = Check_User_Select_Range_Column(OkToProceed)
MsgBox OkToProceed & " After Function call "

'Proceed with MainProgramCode if user data selection is correct
If OkToProceed = True Then
    MsgBox "MainProgramCode"
Else
    Exit Sub
End If

End Sub

2 个答案:

答案 0 :(得分:1)

由于Check_User_Select_Range_Column不返回任何内容, 你应该改变

OkToProceed = Check_User_Select_Range_Column(OkToProceed)

Check_User_Select_Range_Column OkToProceed

但是以下情况更好。

Function Check_User_Select_Range_Column()
If Selection.Column = 1 Then
MsgBox "You selected data from column 1"
Check_User_Select_Range_Column = True
Else
MsgBox "You did not select data from column 1, please try again."
Check_User_Select_Range_Column = False
End If
End Function


Sub MainProgramCode()
Dim OkToProceed As Boolean

'Do some error checking
MsgBox OkToProceed & " Before Function call "
OkToProceed = Check_User_Select_Range_Column()
MsgBox OkToProceed & " After Function call "

'Proceed with MainProgramCode if user data selection is correct
If OkToProceed = True Then
MsgBox "MainProgramCode"
Else
Exit Sub
End If

End Sub

答案 1 :(得分:0)

问题的根本原因是您不了解如何从VBA函数返回值。要从函数返回值,可以将该值分配给函数的名称。

Microsoft Dev Center VBA reference docs

“要从函数返回值,请将该值分配给该函数 名称。任何数量的此类分配都可以出现在 程序。如果没有为名称分配任何值,则该过程返回一个 默认值:数字函数返回0,字符串函数返回 一个零长度的字符串(“”),并且Variant函数返回Empty。 “

yamashiro.akihito的答案演示了正确的用法。