BookmarkSubscribeRSS Feed
thanikondharish
Fluorite | Level 6

data s ;

input id $ result $ ;

cards ;

111   482

112   854

113    neg

114    pos

115    45.5

;

 

extract numeric values and character values from result variable?

4 REPLIES 4
novinosrin
Tourmaline | Level 20
data s ;

input id $ result $ ;

cards ;
111   482
112   854
113    neg
114    pos
;

data want;
set s;
n=compress(result,' ','kd');
c=compress(result,' ','d');
run;
RW9
Diamond | Level 26 RW9
Diamond | Level 26

Show what the output should look like.  Do you want a numeric column with those which are numeric converted?  Would you like separate datasets, etc?  For columns:

data want;
set s;
if not anyalpha(result) then num_var=input(result,best.);
run;
s_manoj
Quartz | Level 8

Hi,

Check below code

 

data want;
set s;
if input(result, best.) then numeric = result;
else char = result;
run;
RW9
Diamond | Level 26 RW9
Diamond | Level 26

You have warnings in that code though about converting text to numeric, actually I fell into the same trap as I forgot that ifn() will do the conversion regardless of the if part.  I updated my code to avoid this.

sas-innovate-2026-white.png



April 27 – 30 | Gaylord Texan | Grapevine, Texas

Registration is open

Walk in ready to learn. Walk out ready to deliver. This is the data and AI conference you can't afford to miss.
Register now and lock in 2025 pricing—just $495!

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
  • 4 replies
  • 1847 views
  • 0 likes
  • 4 in conversation