BookmarkSubscribeRSS Feed
saspert
Pyrite | Level 9

HI,

My input field is something like this -

 

ALICE REV 2-KY/CB 

ALICE-REV 2/BHP
Audition/BTT
Audition-CK/BT

 

and my output field needs to be somehting like this -

ALICE

Audition

 

I have a vague idea about PRX functions. Any help will be appreciated.

 

Thanks,

saspert

3 REPLIES 3
BrunoMueller
SAS Super FREQ

Have a go with this sample, check the doc for the Tables of Perl Regular Expression (PRX) Metacharacters

 

data want;
  infile cards ;
  input text $64.;

  wordEnd = prxmatch("/\W+\b/", text);
  word = substr(text, 1, wordEnd-1);
  putlog _all_;
cards;
ALICE REV 2-KY/CB 
ALICE-REV 2/BHP
Audition/BTT
Audition-CK/BT
;

Bruno

Astounding
PROC Star

If you know the delimiters that might appear in your data, you can code this simply:

 

data want;

set have;

string = scan(string, 1, '- /');

run;

 

Be sure to include a blank as one of the delimiters.

slchen
Lapis Lazuli | Level 10


proc sql;
select distinct(prxchange('s/(^\w+)\W+?.*/$1/i',1,text)) as string from want;
quit;

hackathon24-white-horiz.png

2025 SAS Hackathon: There is still time!

Good news: We've extended SAS Hackathon registration until Sept. 12, so you still have time to be part of our biggest event yet – our five-year anniversary!

Register Now

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
  • 3 replies
  • 1557 views
  • 6 likes
  • 4 in conversation