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

I think it's easiest to describe my goal by showing the type of data I have and the format I want to go into. Is there a simple way to achieve this? Thank you in advance!

mariko5797_0-1633537542449.png

mariko5797_1-1633537560139.png

Dummy dataset to use... NOTE: I have zero clue on how to add missing values with this, so the dummy code would need to be tweaked. Sorry

data dummy;
input id incexc1 $9. type1 $ incexc2 $9. type2 $;
cards;
1 INCLUSION IN102 INCLUSION IN103
1 EXCLUSION EX103 INCLUSION IN112
2 INCLUSION IN106
3 INCLUSION IN109 EXCLUSION EX106
3 INCLUSION IN102
3 EXCLUSION EX104
4 INCLUSION IN107 INCLUSION IN110
5 EXCLUSION EX106 INCLUSION IN101
5 EXCLUSION EX108
;
run;

My first attempt was the below code. Obviously this won't work b/c it will only concatenate what's in the same row not same ID.

data dummy;
 set dummy;
 if not missing(incexl1) and missing(incexl2) then incexcrs = trim(incexl1);
	else if missing(incexl1) and not missing(incexl2) then incexcrs = trim(incexl2);
	else if not missing(incexl1) and not missing(incexl2) then incexcrs = trim(incexl1) ||', '|| trim(incexl2);
	else incexcrs = '';
run;
1 ACCEPTED SOLUTION

Accepted Solutions
Reeza
Super User

Use the first approach outlined here (https://gist.github.com/statgeek/d583cfa992bf56da51d435165b07e96a) for each column - TYPE1 and TYPE2 stored into TYPE1_LIST and TYPE2_LIST (note that in SAS you cannot have variables with the same name, so I'm assuming that you have different names than shown.

Then combine them at the end by adding:

 

if last.ID then do;
 inc_excl_type = catt(type1_list, type2_list);
output;
end;

 

 

 

 

View solution in original post

4 REPLIES 4
Reeza
Super User

Use the first approach outlined here (https://gist.github.com/statgeek/d583cfa992bf56da51d435165b07e96a) for each column - TYPE1 and TYPE2 stored into TYPE1_LIST and TYPE2_LIST (note that in SAS you cannot have variables with the same name, so I'm assuming that you have different names than shown.

Then combine them at the end by adding:

 

if last.ID then do;
 inc_excl_type = catt(type1_list, type2_list);
output;
end;

 

 

 

 

ballardw
Super User

Do you expect results in that exact order?

That is much harder than providing both "types" from a single record first.

 

An example of a data step to read "missing" values from your "example". The dot character will be read as missing

character value if the only character encountered.

data dummy;
   input id incexc1 $9. type1 $ incexc2 $9. type2 $;
cards;
1 INCLUSION IN102 INCLUSION IN103
1 EXCLUSION EX103 INCLUSION IN112
2 INCLUSION IN106 .         .
3 INCLUSION IN109 EXCLUSION EX106
3 INCLUSION IN102 .         .
3 EXCLUSION EX104 .         .
4 INCLUSION IN107 INCLUSION IN110
5 EXCLUSION EX106 INCLUSION IN101
5 EXCLUSION EX108 .         .
;

I don't know what you copied from to post that dummy data step but please review the next time you post one. What ever source seems not to have a proper end of line character.

Card (or Datalines same thing) must appear on a line by itself as does the ; or ;;;; (with Cards4) to end the data.

 

 

mariko5797
Pyrite | Level 9

Thank you!

And I have zero clue why, but posting SAS code in SAS Community doesn't always keep my "next" lines if that makes sense. My code will be on multiple lines, but will post as one. I didn't know 'cards' had to be on its own line though (I always just blindly copied it that way), so good to know!

Reeza
Super User
Typically this happens if you edit the code after you've posted in the code box but not in the code editor.

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 25. 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
  • 4 replies
  • 760 views
  • 1 like
  • 3 in conversation