Sabtu, 25 Juli 2015

RE: [MS_AccessPros] Re: What does the colon do in the ELSE: statement?

 

It will compile Bill, but I don't like it J

 

I never use multiple statements with an Else. I used to be very 'correct' with no else and code it like

If suit = spades Then

 

    MsgBox "I win!"

End If

But I admit I prefer single lines and that is what I use now (does cause some small problems when trying to check back on multiple nested Ifs when there is one without an End If, but nesting usually helps here).

 

BTW, typing endif and getting End If is great in my view, I always do it and love that VBA corrects it (in the same way that I never type my variables in the define came-case, I type them lower-case and if they don't get corrected I know I have typed it incorrectly – we need all the help we can get), but I just wish it would work with endwith as well!

 

From: MS_Access_Professionals@yahoogroups.com [mailto:MS_Access_Professionals@yahoogroups.com]
Sent: 24 July 2015 17:29
To: MS_Access_Professionals@yahoogroups.com
Subject: RE: [MS_AccessPros] Re: What does the colon do in the ELSE: statement?

 

 

Bob - It's a non-nonsensical example made worse by being syntactically incorrect to start with.But my example is correct and will compile as it should.

 

While multiple statement lines are out of the ordinary, they are used from time to time. It's a matter of style. I tend to use them in If blocks if the Else line is short. Offhand, I can't think of any other place I'd use them.

 

Then there is the one-line If statement:

If suit = spades  Then MsgBox "I win!"

 

No End If needed.

Another funny thing about VBA, you can type endif and the editor will fix it for you.

 

-Bill



---In MS_Access_Professionals@yahoogroups.com, <bob.phillips@dsl.pipex.com> wrote :

Surely, it should be

 

 

   If 1 > 4 Then

      MsgBox "1 is greater than 4"

  Else

      MsgBox "1 is less than 4"

  End If

 

Or even

 

  MsgBox "1 is " & IIf(1 > 4, "greater", "less") & " than 4"

 

Multiple statement lines just don't feel right to me.

 

From: MS_Access_Professionals@yahoogroups.com [mailto:MS_Access_Professionals@yahoogroups.com]
Sent: 24 July 2015 16:24
To: MS_Access_Professionals@yahoogroups.com
Subject: [MS_AccessPros] Re: What does the colon do in the ELSE: statement?

 

 

Phucon

 

As per Duane's explanation, the code should have been written:

 

   If 1 > 4 Then

      MsgBox "1 is greater than 4"

  Else: MsgBox "1 is less than 4"

  End If

 

Regards,

Bill Mosca, Founder - MS_Access_Professionals

Microsoft Office Access MVP

My nothing-to-do-with-Access blog

 



---In MS_Access_Professionals@yahoogroups.com, <duanehookom@hotmail.com> wrote :

I found this while searching the web http://stackoverflow.com/questions/7649101/excel-vba-pound-and-colon-signs-meaning
 
"The colon (:) is a statement delimiter. It would be equivalent to a new line in VBA, or a semicolon in C (just to quote a random example). It allows you to write several instructions on a single line rather than going to a new line each time."
 
Since your example code has not instruction on the same line after the ":" it serves no purpose.
 
Duane Hookom, MVP
MS Access
 


To: MS_Access_Professionals@yahoogroups.com
From: MS_Access_Professionals@yahoogroups.com
Date: Thu, 23 Jul 2015 08:21:06 -0700
Subject: [MS_AccessPros] What does the colon do in the ELSE: statement?



 
Hello
 
I am trying to understand the "ELSE:". Why is the colon necessary? What does it do there?
 
Thank you
 
Phucon
 
Sub IF_ELSEIF_FUNCTION()
  If 1 > 4 Then
      MsgBox "1 is greater than 4"
  Else:
      MsgBox "1 is less than 4"
  End If
End Sub

 

 

__._,_.___

Posted by: "Bob Phillips" <bob.phillips@dsl.pipex.com>
Reply via web post Reply to sender Reply to group Start a New Topic Messages in this topic (7)

.

__,_._,___

Tidak ada komentar:

Posting Komentar