BookmarkSubscribeRSS Feed
🔒 This topic is solved and locked. Need further help from the community? Please sign in and ask a new question.
That____Redhead
Fluorite | Level 6

Hey all,

I can't seem to find a quick way of doing this.  I have a string variable, and if the 3rd character is a number, it is indicative of a business, if it is a letter it is an individual.  What is the easiest way to determine this?

I have tried marker = (substr(var,3,1) IN(0:9)); but then when it's text, it gives errors.

Thanks!    

1 ACCEPTED SOLUTION

Accepted Solutions
Haikuo
Onyx | Level 15

Try this:

data have;

input string$ @@;

cards;

adsflk ad2eif ad0euh

;

data want;

set have;

Digiornot=anydigit(substr(string,3,1));

put '1-Digit 0-None Digit' digiornot=;

run;

Haikuo

View solution in original post

2 REPLIES 2
Haikuo
Onyx | Level 15

Try this:

data have;

input string$ @@;

cards;

adsflk ad2eif ad0euh

;

data want;

set have;

Digiornot=anydigit(substr(string,3,1));

put '1-Digit 0-None Digit' digiornot=;

run;

Haikuo

That____Redhead
Fluorite | Level 6

Thanks!    

How to Concatenate Values

Learn how use the CAT functions in SAS to join values from multiple variables into a single value.

Find more tutorials on the SAS Users YouTube channel.

SAS Training: Just a Click Away

 Ready to level-up your skills? Choose your own adventure.

Browse our catalog!

Discussion stats
  • 2 replies
  • 1336 views
  • 1 like
  • 2 in conversation