BookmarkSubscribeRSS Feed
zz
Calcite | Level 5 zz
Calcite | Level 5

I need to make field values as new column headings and would greatly appreciate help on the below:

 

Program to go through below dataset:

 

SUB CEDECODN              DATE          FATEST                                                       FASTRESC
1      INITIAL DIAGNOSIS 10/10/2015 Ann Arbor Classification                               Stage IV
1      INITIAL DIAGNOSIS 10/11/2015 B-Symptoms                                                 PRESENT
1      INITIAL DIAGNOSIS 10/12/2015 Type of Non-Hodgkin Lymphoma                INDOLENT
1      INITIAL DIAGNOSIS 10/13/2015 Histology of lymphoma                                Follicular lymphoma
1      INITIAL DIAGNOSIS 10/14/2015 Follicular lymphoma grade                          Grade 3a

 

And Format the data as follows:

 

SUBJECT INITIAL DIAGNOSIS Ann Arbor Classification B-Symptoms Type of Non-Hodgkin Lymphoma Histology of lymphoma Follicular lymphoma grade
1               10/14/2015               Stage IV                          PRESENT     INDOLENT                                   Follicular lymphoma

Grade 3a

 

Thank you very much in advance.

 

ZZ

2 REPLIES 2
Shmuel
Garnet | Level 18

In order to save only the last DATE I prefer use a data step instead of the TRANSPOSE procedure.

 

%let max oc = 10;  /* change to max of distinct FATEST values */

data want;

  set have;

    by SUB CEDECODN  DATE ;

        length  fatest1-fatest&oc $30 fastresc1-fastrec&oc $20;   /* addapt length to maximum as need */

        retain fatest1-fatest&oc  fastresc1-fastresc&oc  i;

        array  tstx {&oc}  fatest1-fatest&oc;

        array  rscx {&oc} fastresc1-fastresc&oc ;

 

        if first.CEDECODN   then do;

          do i=1 to &oc; tstx(i)=' '; rscx(i)=' '; end;   /* initiate by space */

          i = 1;

        end;

        

        if i le &oc then do;

             tstx(i) = FATEST  ;

             rscx(i) = FASTRESC ;

       end;

       else put 'WARNING: There are more then ' &oc ' distinct values.';

 

       if last.CEDECODN   then output;

      DROP i FATEST  FASTRESC;

run;

        

Shmuel
Garnet | Level 18
Need add a line:
if i le &oc then do;
tstx(i) = FATEST ;
rscx(i) = FASTRESC ;
i+1; /* <<<<<<< */
end;

hackathon24-white-horiz.png

The 2025 SAS Hackathon has begun!

It's finally time to hack! Remember to visit the SAS Hacker's Hub regularly for news and updates.

Latest Updates

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
  • 1435 views
  • 0 likes
  • 2 in conversation