BookmarkSubscribeRSS Feed
SASPhile
Quartz | Level 8

The values of a column, no special characters are allowed and use an underscore to mark spaces?

3 REPLIES 3
Daisy
Calcite | Level 5

Is this what you are looking for ?

x2=compress(tranlate(x1,'_',' '), '~!@#$%^&*()+|}{[]\<>?');


x1=your original column

x2=new output

note : you could change the list of special characters you want to remove.

Haikuo
Onyx | Level 15

Sometimes it is difficult to exhaust or even define special characters, that is where 'k' modifier coming in handy:

x2=compress(translate(x1,'_',' '),'_','kda');

Haikuo

Ksharp
Super User

What legal characters do you want ?

data x;
 x="x2=compress(tranlate(x1,'_sdsd',' '),   '~!@#$%^*()+|}{[]\<>?');";
 xx=prxchange('s/\W//o',-1,translate(compbl(x),'_',' '));
run;


Ksharp

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
  • 1725 views
  • 3 likes
  • 4 in conversation