IF then statement is used to run the certain code when given condition is true and if condition is false then some other code will execute. We must close the IF statement with End IF.
In the below example we are asking a question by using Message box. If user clicks on Yes, then we know it will return 6 and if user clicks on No then it will return 7. So, we have taken condition to show the message box for the click of yes and no.
Sub IF_else_Then() Dim s As Integer s = MsgBox("Do you like VBA?", vbQuestion + vbYesNo) If s = 6 Then MsgBox "You clicked on Yes" Else MsgBox "You clicked on No" End If End Sub
When we run this code, it will show below given message.
data:image/s3,"s3://crabby-images/58c91/58c91133e2eac0ae2e9ef3524eb4175b1223d621" alt="Message Popup"
If you click on Yes button, then it will return-
data:image/s3,"s3://crabby-images/839f3/839f3f3a2eb63de6b95d0fc7f0d41202f673ec23" alt="Result for Yes"
If you click on No button, then it will return-
data:image/s3,"s3://crabby-images/861e2/861e293e1432b41a382194c53494c9e693a76787" alt="Result for No"
ELSEIF
Elseif is used to use more than one condition. See the below given example.
Sub IF_And_ElseIF() Dim x As Integer Dim y As Integer x = VBA.InputBox("Please enter the value to x") y = VBA.InputBox("Please enter the value to y") If x > y Then MsgBox "x is greater than y" ElseIf y > x Then MsgBox "y is greater than x" Else MsgBox "X is equal to Y" End If End Sub
When we will run this code, we must input x and y value as number.
I have given value of x as 5
data:image/s3,"s3://crabby-images/47c3b/47c3bbf9813ff5494af1150b1df3b1f6c47415c2" alt="Input value of x"
I have given value of y as 10
data:image/s3,"s3://crabby-images/69182/691820852b3c35570dd9d832c17d9745fa508548" alt="Input value of y"
Now it will show the result
data:image/s3,"s3://crabby-images/51728/5172886243b7f217eb941fd65fbe1c02ed59e000" alt="Result popup"
Watch the IF ELSE THEN tutorial video
Click here to download the practice file