?
Solved

Select Case combined with like operator

Posted on 2003-12-09
9
Medium Priority
?
855 Views
Last Modified: 2010-05-01
Hi,

I can't find a way to do what i'm after.

I need a select case function that will allow for the like operator.

eg..

case like "*ABC"
     blahblah
case like "*123*"
    blahblah2

I need to match the patern of the case to wildcard entries - but all I can find is that the like operator with wildcards won't work within a select case.

Any ideas anyone?

Thanks,

Benjamin.
0
Comment
Question by:benspan
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2
  • 2
  • 2
  • +2
9 Comments
 
LVL 5

Expert Comment

by:mccainz2
ID: 9909202
why not use an if - elseif structure ...

if case like "*abc"
0
 
LVL 5

Expert Comment

by:mccainz2
ID: 9909207
Argghhh, hit enter on my touchoad ..

why not use an if - elseif structure ...

if case like "*abc"
.....
else if case like "*whatever"
.. etc
0
 
LVL 27

Expert Comment

by:Dabas
ID: 9909214
Hi benspan,
I suggest you have a look at regular expressions.

Search for regex here on EE, or have a look at this question

http://oldlook.experts-exchange.com/Programming/Programming_Languages/Visual_Basic/Q_20528014.html

The last answer has a link to Microsoft with even more information.

Learning Regular Expressions is not simple, but once you get the gist of it, you will see that it can solve not just this particular problem you are having, but many more, to the point that it may become addictive!


Dabas
0
VIDEO: THE CONCERTO CLOUD FOR HEALTHCARE

Modern healthcare requires a modern cloud. View this brief video to understand how the Concerto Cloud for Healthcare can help your organization.

 
LVL 2

Expert Comment

by:lttia1
ID: 9909250
you can also make use of this if using if-else statement:

If InStr(Text1.Text, "ABC") <> 0 Then
   blahblah
ElseIf InStr(Text1.Text, "123") <> 0 Then
    blahblah
End if
0
 

Author Comment

by:benspan
ID: 9909586
I'm trying to avoid a massive if then listing, so was trying to use the select case calls.

The instr is pretty much the like statement with wildcard values by the looks.

What i'm really trying to find out is if it is possible to use the select case statement to do fancy comparisons...

select case something

     case something like "*ABC*"
           x
     case something like "*BCD*"
           y

etc etc

the following format works:
select case something
    case is = "A"
          x
    case is = "B"
          y
etc etc, but this will only match exact values - whereas i want to match values with wildcards.

looks as though the case statement just can't handle this?
0
 
LVL 27

Expert Comment

by:Dabas
ID: 9909671
benspan,
> looks as though the case statement just can't handle this?
Right.
The case statement cannot handle this.
Regex is the way to go!

Dabas
0
 
LVL 39

Expert Comment

by:appari
ID: 9910308
can try something like this

Private Sub Command1_Click()
Dim x As String

x = InputBox("Enter Name")
Select Case True
Case x Like "*Appari"
    MsgBox "has Appari"
Case x Like "*Dabas"
    MsgBox "has Dabas"

End Select
End Sub
0
 
LVL 39

Accepted Solution

by:
appari earned 200 total points
ID: 9910311
missed ending *

can try something like this

Private Sub Command1_Click()
Dim x As String

x = InputBox("Enter Name")
Select Case True
Case x Like "*Appari*"
    MsgBox "has Appari"
Case x Like "*Dabas*"
    MsgBox "has Dabas"

End Select
End Sub
0
 

Author Comment

by:benspan
ID: 9917009
Perfect - exactly what i am trying to do.

you're definitely a guru.

Thanks.
0

Featured Post

What does it mean to be "Always On"?

Is your cloud always on? With an Always On cloud you won't have to worry about downtime for maintenance or software application code updates, ensuring that your bottom line isn't affected.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

The debugging module of the VB 6 IDE can be accessed by way of the Debug menu item. That menu item can normally be found in the IDE's main menu line as shown in this picture.   There is also a companion Debug Toolbar that looks like the followin…
Enums (shorthand for ‘enumerations’) are not often used by programmers but they can be quite valuable when they are.  What are they? An Enum is just a type of variable like a string or an Integer, but in this case one that you create that contains…
As developers, we are not limited to the functions provided by the VBA language. In addition, we can call the functions that are part of the Windows operating system. These functions are part of the Windows API (Application Programming Interface). U…
Get people started with the process of using Access VBA to control Excel using automation, Microsoft Access can control other applications. An example is the ability to programmatically talk to Excel. Using automation, an Access application can laun…
Suggested Courses

764 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question