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

Hi All,

Data have;

input id    mut $;

cards;

100    mut1

100    nomut

100    mut3

101    mut3

101    mut4

105    mut5

105    nomut

105    mut6

;

run;

i want like this

100           mut1/nomut/mut3

101           mut3/mut4

105           mut5/nomut/mut6

Thanks in Advance

Sam


1 ACCEPTED SOLUTION

Accepted Solutions
art297
Opal | Level 21

Here is one way to do it, but this would leave it up to you to specify the length needed to capture the new field:

data want (drop=mut);

  set have;

  by id;

  length newfield $100;

  retain newfield;

  if first.id then newfield=mut;

  else newfield=catx('/',newfield,mut);

  if last.id then output;

run;

View solution in original post

2 REPLIES 2
art297
Opal | Level 21

Here is one way to do it, but this would leave it up to you to specify the length needed to capture the new field:

data want (drop=mut);

  set have;

  by id;

  length newfield $100;

  retain newfield;

  if first.id then newfield=mut;

  else newfield=catx('/',newfield,mut);

  if last.id then output;

run;

sam369
Obsidian | Level 7

Thank you so much Art!!!!


What is Bayesian Analysis?

Learn the difference between classical and Bayesian statistical approaches and see a few PROC examples to perform Bayesian analysis in this video.

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