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

How SAS gurus,

 

I have a simple question but couldn't figure it out. Not sure if it is doable but your help will be appreciated.

If a data set has two columns, one is the value, the other is the format, how can I created a third Column using the value of the two?

 

proc format  ;

value go

0='no' 1='yes';

value to

0='missing' 1='present';

run;

 

DATA temp;
INPUT value variable $ ;
DATALINES;1 go
1 to
;

My goal is to crate a third variable new using put(value,variable.) as a formula.  

 

I have tried using sql to created a formula, in this example, put(1.go.) and put(1, to.)  and how can I made data looks like:

 

value variable new 
1 go yes
1 to present
;

Thanks!

 

1 ACCEPTED SOLUTION

Accepted Solutions
Tom
Super User Tom
Super User

SAS needs to compile the data step before it starts running. If you have CODE in DATA then you will need to first run a step to generate a complete data step.  Then SAS can compile it and run it.  You can use CALL EXECUTE( ) or write the code to a file and use %INCLUDE to run it.

 

data have;
 input variable $ value decode $20.;
cards;
  go            0      put(0,go.)
  go            1     put(1,go.)
  to            0     put(0,to.)
  to            1     put(1,to.)
;

proc format ;
 value go 1='Go' other='Stay';
 value to 1='There' other='Here';
run;

filename code temp;
data _null_;
  set have ;
  file code ;
  put 'if ' _n_ =  ' then new=' decode ';' ;
run;

data want;
  set have ;
  length new $20. ;
  %include code/source2;
run;
Obs    variable    value      decode      new

 1        go         0      put(0,go.)    Stay
 2        go         1      put(1,go.)    Go
 3        to         0      put(0,to.)    Here
 4        to         1      put(1,to.)    There

 Log

1450  data want;
1451    set have ;
1452    length new $20. ;
1453    %include code/source2;
NOTE: %INCLUDE (level 1) file CODE is file .../#LN00047.
1454 +if _N_=1  then new=put(0,go.) ;
1455 +if _N_=2  then new=put(1,go.) ;
1456 +if _N_=3  then new=put(0,to.) ;
1457 +if _N_=4  then new=put(1,to.) ;
NOTE: %INCLUDE (level 1) ending.
1458  run;

NOTE: There were 4 observations read from the data set WORK.HAVE.
NOTE: The data set WORK.WANT has 4 observations and 4 variables.

View solution in original post

6 REPLIES 6
SuryaKiran
Meteorite | Level 14

Hi,

 

Welcome to SAS Community. 

 

Can you be more specific, it is not so clear what your trying to do here. Simply present the data you have and what is the output your expecting.

Thanks,
Suryakiran
songlh15
Calcite | Level 5

Thanks for your quick response!

I received a data set with two separated variables as my example shown above,.  I'm trying to create one new variable using values existing two existing variables.  

current data:

Variable Value

go  1

to 1

I wanted to create a new variable called new using values from Variable and Value, the output should be

Variable Value New

go  1 yes

to 1 present

 

Thanks again.

 

 

 

 

 

Tom
Super User Tom
Super User

The PUTN() and PUTC() functions can use an expression for the name of the format.

First let's make your formats using names that are more descriptive of what they do.  Let's also make a format we can use to associate which format is used for which variable name.

proc format  ;
  value yesno  1='yes' other='no';
  value present 1='present' other='missing';
  value $format 'GO'='YESNO.' 'TO'='PRESENT.' ;
run;

Now let's make some test data:

data temp;
  length variable $32 value 8;
  do variable='go','to';
    do value=0,1;
      output;
    end;
  end;
run;

And now let's figure out what decode to generate for each value/variable pair.

data want ;
  set temp;
  length decode $50 ;
  decode = putn(value,put(upcase(variable),$format.));
run;
Obs    variable    value    decode

 1     go            0      no
 2     go            1      yes
 3     to            0      missing
 4     to            1      present
songlh15
Calcite | Level 5

Thanks so much, your code works for that task!

 

One step further, if  put(value,variable.) string have been generated  in third variable, how can we retrieve the value? in other words, how can we make the third variable run? Taking the same data as an example, if a table is given below, how can we let decode run and get the correct format?

 

Thanks!

 

Obs    variable    value    decode

 1     go            0      put(0,go.)  
2 go 1 put(1,go.) 3 to 0 put(0,to.) 4 to 1 put(1,to.)
Tom
Super User Tom
Super User

SAS needs to compile the data step before it starts running. If you have CODE in DATA then you will need to first run a step to generate a complete data step.  Then SAS can compile it and run it.  You can use CALL EXECUTE( ) or write the code to a file and use %INCLUDE to run it.

 

data have;
 input variable $ value decode $20.;
cards;
  go            0      put(0,go.)
  go            1     put(1,go.)
  to            0     put(0,to.)
  to            1     put(1,to.)
;

proc format ;
 value go 1='Go' other='Stay';
 value to 1='There' other='Here';
run;

filename code temp;
data _null_;
  set have ;
  file code ;
  put 'if ' _n_ =  ' then new=' decode ';' ;
run;

data want;
  set have ;
  length new $20. ;
  %include code/source2;
run;
Obs    variable    value      decode      new

 1        go         0      put(0,go.)    Stay
 2        go         1      put(1,go.)    Go
 3        to         0      put(0,to.)    Here
 4        to         1      put(1,to.)    There

 Log

1450  data want;
1451    set have ;
1452    length new $20. ;
1453    %include code/source2;
NOTE: %INCLUDE (level 1) file CODE is file .../#LN00047.
1454 +if _N_=1  then new=put(0,go.) ;
1455 +if _N_=2  then new=put(1,go.) ;
1456 +if _N_=3  then new=put(0,to.) ;
1457 +if _N_=4  then new=put(1,to.) ;
NOTE: %INCLUDE (level 1) ending.
1458  run;

NOTE: There were 4 observations read from the data set WORK.HAVE.
NOTE: The data set WORK.WANT has 4 observations and 4 variables.
songlh15
Calcite | Level 5

Awesome! This is so helpful! 

 

SAS Innovate 2025: Call for Content

Are you ready for the spotlight? We're accepting content ideas for SAS Innovate 2025 to be held May 6-9 in Orlando, FL. The call is open until September 16. Read more here about why you should contribute and what is in it for you!

Submit your idea!

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.

Click image to register for webinarClick image to register for webinar

Classroom Training Available!

Select SAS Training centers are offering in-person courses. View upcoming courses for:

View all other training opportunities.

Discussion stats
  • 6 replies
  • 1200 views
  • 2 likes
  • 3 in conversation