Jump to content

Is it possible to use a UDF as the Expression in a Switch statement?


timmy2
 Share

Go to solution Solved by KaFu,

Recommended Posts

Here's a working of my simple code test.

Global $var

Call ("EnterData")

Switch Int($var)
    Case 0
        MsgBox(1,"","entry was 0 ")
    Case 1
        MsgBox(1,"","entry was 1 ")
    Case 2
        MsgBox(1,"","entry was 2 ")
    Case Else
        MsgBox(1,"","entry was something else")
EndSwitch

;---------------
Func EnterData()
    $var = InputBox("enter a number","Enter a number between 0 and 9 :")
EndFunc

Is there a way to use the function call that fetches the value to evaluated in the Switch statement? I tried the following but it always resolves to Case 0.

Global $var

Switch Int(EnterData())
    Case 0
        MsgBox(1,"","entry was 0 ")
    Case 1
        MsgBox(1,"","entry was 1 ")
    Case 2
        MsgBox(1,"","entry was 2 ")
    Case Else
        MsgBox(1,"","entry was something else")
EndSwitch


Func EnterData()
    $var = InputBox("","Enter a number between 0 and 9 :")
EndFunc
Link to comment
Share on other sites

Try this:

Global $var = EnterData()

Switch $var
    Case 0
        MsgBox(1,"","entry was 0 ")
    Case 1
        MsgBox(1,"","entry was 1 ")
    Case 2
        MsgBox(1,"","entry was 2 ")
    Case Else
        MsgBox(1,"","entry was something else")
EndSwitch

;---------------
Func EnterData()
    Return Int(InputBox("enter a number","Enter a number between 0 and 9 :"))
EndFun

My UDFs and Tutorials:

Spoiler

UDFs:
Active Directory (NEW 2022-02-19 - Version 1.6.1.0) - Download - General Help & Support - Example Scripts - Wiki
ExcelChart (2017-07-21 - Version 0.4.0.1) - Download - General Help & Support - Example Scripts
OutlookEX (2021-11-16 - Version 1.7.0.0) - Download - General Help & Support - Example Scripts - Wiki
OutlookEX_GUI (2021-04-13 - Version 1.4.0.0) - Download
Outlook Tools (2019-07-22 - Version 0.6.0.0) - Download - General Help & Support - Wiki
PowerPoint (2021-08-31 - Version 1.5.0.0) - Download - General Help & Support - Example Scripts - Wiki
Task Scheduler (NEW 2022-07-28 - Version 1.6.0.1) - Download - General Help & Support - Wiki

Standard UDFs:
Excel - Example Scripts - Wiki
Word - Wiki

Tutorials:
ADO - Wiki
WebDriver - Wiki

 

Link to comment
Share on other sites

  • Solution

Or something like this?

Switch EnterData()
    Case 0
        MsgBox(1, "", "entry was 0 ")
    Case 1
        MsgBox(1, "", "entry was 1 ")
    Case 2
        MsgBox(1, "", "entry was 2 ")
    Case Else
        MsgBox(1, "", "entry was something else")
EndSwitch

Func EnterData()
    Return Int(InputBox("", "Enter a number between 0 and 9 :"))
EndFunc   ;==>EnterData
Link to comment
Share on other sites

Glad to be of service :)

My UDFs and Tutorials:

Spoiler

UDFs:
Active Directory (NEW 2022-02-19 - Version 1.6.1.0) - Download - General Help & Support - Example Scripts - Wiki
ExcelChart (2017-07-21 - Version 0.4.0.1) - Download - General Help & Support - Example Scripts
OutlookEX (2021-11-16 - Version 1.7.0.0) - Download - General Help & Support - Example Scripts - Wiki
OutlookEX_GUI (2021-04-13 - Version 1.4.0.0) - Download
Outlook Tools (2019-07-22 - Version 0.6.0.0) - Download - General Help & Support - Wiki
PowerPoint (2021-08-31 - Version 1.5.0.0) - Download - General Help & Support - Example Scripts - Wiki
Task Scheduler (NEW 2022-07-28 - Version 1.6.0.1) - Download - General Help & Support - Wiki

Standard UDFs:
Excel - Example Scripts - Wiki
Word - Wiki

Tutorials:
ADO - Wiki
WebDriver - Wiki

 

Link to comment
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
 Share

  • Recently Browsing   0 members

    • No registered users viewing this page.
×
×
  • Create New...