Case statement with multiple ANDed conditions

JenniferMurphy

Well-known Member
Joined
Jul 23, 2011
Messages
2,709
Office Version
  1. 365
Platform
  1. Windows
I need a Case statement that will be true if a value is >=0 AND <=1. Here's what I have tried, none of which work:

Code:
Case Is >= 0, Is <= 1          'True for all values
Case Is >= 0 and Is <= 1       'Syntax error
Case >= 0 and <= 1             'Syntax error
Case is >= 0 andalso is <= 1   'Syntax error
Case is >= 0, andalso is <= 1  'Syntax error

Is there a way to code multiple tests that must all be true (ANDed) on a single Case statement in VBA?

If not, what's the best workaround?
 

Excel Facts

Does the VLOOKUP table have to be sorted?
No! when you are using an exact match, the VLOOKUP table can be in any order. Best-selling items at the top is actually the best.
Your solution (Case 0 to 1) handles the case where 0 <= x <= 1 [0,1]. What if one or both sides do not include the "=" condition?
Code:
[LIST=1]
[*]0 < x <= 1  '(0,1] 
[*]0 <= x <1   '[0,1) 
[*]0 < x < 1   '(0,1)<x <="" 1="" (0,1)<="" li=""> </x> 
[/LIST]
Is there an expression for those situations?
 
Upvote 0
It depends what your other conditions are and what your possible values for x are. For example, if x can not be negative and you wanted to deal with the ranges
0<=x<1
1<=x<5
5<=x<7
then something like
Code:
Select Case x
  Case Is < 1
  Case Is < 5
  Case Is < 7
  Case Else
End Select

If x could be any number and the only ranges you want to work with are
1<x<=5
12<=x<20
then you can use a structure like this
Code:
Select Case True
  Case x > 1 And x <= 5
  Case x >= 12 And x < 20
End Select
 
Upvote 0
If x could be any number and the only ranges you want to work with are
1 < x <=5
12<=x<20

Another approach would be
Code:
Select Case x
    Case Is <=1
        ' blank line, do nothing
    Case is <=5
        MsgBox "Between 1 and 5"
    Case is <12
        ' blank line, do nothing
    Case is <20
        MsgBox "between 12 and 20"
    Case Else
End Select
 
Last edited:
Upvote 0
Another approach would be
Code:
Select Case x
    Case Is <=1
        ' blank line, do nothing
    Case is <=5
        MsgBox "Between 1 and 5"
    Case is <12
        ' blank line, do nothing
    Case is <20
        MsgBox "between 12 and 20"
    Case Else
End Select
I agree Mike. My reasoning for using what I did in the second example was that I had already shown that sequential idea in my first example & I wanted to demonstrate the "Select Case True" concept - which many users are unaware of.
 
Upvote 0
So, bottom line: there is no Case statement equivalent to 3 of these 4 If statements:

[TABLE="class: grid, width: 500"]
<tbody>[TR]
[TD="align: center"]If Statement
[/TD]
[TD="align: center"]Equivalent Case Statement
[/TD]
[/TR]
[TR]
[TD]If X > A And X < B
[/TD]
[TD]none
[/TD]
[/TR]
[TR]
[TD]If X > A And X <= B
[/TD]
[TD]none
[/TD]
[/TR]
[TR]
[TD]If X >= A And X < B
[/TD]
[TD]none
[/TD]
[/TR]
[TR]
[TD]If X >= A And X <= B
[/TD]
[TD]Case A to B
[/TD]
[/TR]
</tbody>[/TABLE]

And there is a similar deficiency for even simple Or expressions, let along more complex boolean expressions.

Correct?

It seems pretty clear that Visual Basic was "designed" (I am being extremely charitable) by a robot using a random number generator or, at best, a wannabe software engineer who transferred over from marketing.

The only other possible explanation is that it is a creation of Beelzebub himself as the ultimate eternal punishment reserved for those who spent their lives writing endless loops, incomprehensible error messages, unnormalized data structures. (sigh)
[h=4][/h]
 
Upvote 0

Forum statistics

Threads
1,225,761
Messages
6,186,891
Members
453,383
Latest member
SSXP

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top