Solved

Select Case combined with like operator

Posted on 2003-12-09
9
854 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
Online Training Solution

Drastically shorten your training time with WalkMe's advanced online training solution that Guides your trainees to action. Forget about retraining and skyrocket knowledge retention rates.

 
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 50 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

On Demand Webinar - Networking for the Cloud Era

This webinar discusses:
-Common barriers companies experience when moving to the cloud
-How SD-WAN changes the way we look at networks
-Best practices customers should employ moving forward with cloud migration
-What happens behind the scenes of SteelConnect’s one-click button

Question has a verified solution.

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

There are many ways to remove duplicate entries in an SQL or Access database. Most make you temporarily insert an ID field, make a temp table and copy data back and forth, and/or are slow. Here is an easy way in VB6 using ADO to remove duplicate row…
Most everyone who has done any programming in VB6 knows that you can do something in code like Debug.Print MyVar and that when the program runs from the IDE, the value of MyVar will be displayed in the Immediate Window. Less well known is Debug.Asse…
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…

705 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