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

I am looking to pull out observations with a specific ICD9 code "493" from either the variable PrincipleDiagnosis or any of the SecondaryDiagnosis2-SecondaryDiagnosis20.  I have this array for the secondary diagnosis:

 

data want;

set have;

if principaldiagnosis=:493;

array secondarydiagnosis(*) secondarydiagnosis2-secondarydiagnosis20;

do i= 1 to dim(secondarydiagnosis);

if secondarydiagnosis(i)=: '493' then do;

output;

end;

end;

run;

 

However, how can I also get this to check the variable PrincipalDiagnosis...

if principaldiagnosis=:'493' 

in the same data step?

 

Thanks for your help!!

 

1 ACCEPTED SOLUTION

Accepted Solutions
Reeza
Super User

@jenim514 wrote:

or like this?

 

data want;

set have;

array diagnosis(*) primarydiagnosis secondarydiagnosis2-secondarydiagnosis20;

do i= 1 to dim(diagnosis);

if diagnosis(i)=: '493' then do;

output;

end;

end;

run;


Yes, you can just add the variable in to the list. Arrays are short cuts, nothing more, nothing less.

View solution in original post

8 REPLIES 8
Reeza
Super User

Why separate it? Put the primary in your diagnosis list for secondary and include it in the loop.

 

You can also access it independently if needed by name. 

jenim514
Pyrite | Level 9

I wish I understood arrays better...not sure how, where to include principaldiagnosis in the loop since it is a different variable.

 

data asthma_only;

set champs_j.table_C_MDR;

array primarydiagnosis secondarydiagnosis(*) secondarydiagnosis2-secondarydiagnosis20;

do i= 1 to dim(secondarydiagnosis);

if secondarydiagnosis(i)=: '493' then do;

if principaldiagnosis=:'493' then do;

output;

end;

end;

end;

run;

 

=== ERROR!! 

 

-

 

jenim514
Pyrite | Level 9

or like this?

 

data want;

set have;

array diagnosis(*) primarydiagnosis secondarydiagnosis2-secondarydiagnosis20;

do i= 1 to dim(diagnosis);

if diagnosis(i)=: '493' then do;

output;

end;

end;

run;

Reeza
Super User

@jenim514 wrote:

or like this?

 

data want;

set have;

array diagnosis(*) primarydiagnosis secondarydiagnosis2-secondarydiagnosis20;

do i= 1 to dim(diagnosis);

if diagnosis(i)=: '493' then do;

output;

end;

end;

run;


Yes, you can just add the variable in to the list. Arrays are short cuts, nothing more, nothing less.

Astounding
PROC Star

Also consider this.  If multiple diagnoses all begin with "493" you will output the same observation multiple times.  To prevent that, you could add anothe statement immediately following the output:

 

output;

delete;

 

 

SAS_inquisitive
Lapis Lazuli | Level 10

Array is nothing. It's just a of group of variables that you want perform similar operations on it.

ChrisNZ
Tourmaline | Level 20
To avoid duplicates.

if diagnosis(i)=: '493' then do;
output;
leave;
end;
ChrisNZ
Tourmaline | Level 20

 

It is also possible to test the whole array in one go, for example like below.

 

The first data step runs twice as fast as the second one.

 

data HAVE;

 retain PRIMARYDIAGNOSIS '495' SECONDARYDIAGNOSIS8 '493';

 do I =1 to 1e7; output; end;

 drop I;

run;

 

data WANT;

 array DIAGNOSIS(*) $3 PRIMARYDIAGNOSIS SECONDARYDIAGNOSIS2-SECONDARYDIAGNOSIS20;

 DSID=open('HAVE');

 call set (DSID);

 do until(RC);

  RC=fetch(DSID);

  if RC=0 and whichc('493', of DIAGNOSIS[*]) then output;

 end;

 RC=close(DSID);

run;

 

data WANT;

 array DIAGNOSIS(*) $ PRIMARYDIAGNOSIS SECONDARYDIAGNOSIS2-SECONDARYDIAGNOSIS20;

 set HAVE;

 do I=1 to dim(DIAGNOSIS);

  if DIAGNOSIS[I] =:'493' then do;

   output;

   leave;

  end;

 end;

run;

 

 

More performance tips in

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
  • 8 replies
  • 2070 views
  • 0 likes
  • 5 in conversation