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

Please Assist:

 

How to transpose table 1 to table 2 

Table 1
 CodeAmount
Name 1286R 100
Name 1687R 500
Name 2878R 250
Name 3125R 1 000
Name 3236R 980
Name 4125R 1 244
Name 4236R 1 470
   

 

 

Table 2
 Code_1Amount_1Code_2Amount_2
Name 1286R 100687R 500
Name 2878R 250 R 0
Name 3125R 1 000236R 980
Name 4125R 1 244236R 1 470

 

Thank you.

1 ACCEPTED SOLUTION

Accepted Solutions
Ksharp
Super User
Data Table_1;
Input Name$ code$ Amount;
cards;
John 2 100
John 6 500
Lucia 8 250
Josh 1 1000
Josh 2 980
Tim 1 1244
Tim 2 1470
;

run;

proc sql noprint;
select max(n) into : n
 from ( select count(*) as n from table_1 group by name );
quit;
proc summary data=table_1 nway;
class name;
output out=want idgroup(out[&n] (code amount)=);
run;

View solution in original post

6 REPLIES 6
Kurt_Bremser
Super User

Run a transpose each for code and amount, and merge the two resulting tables.

For code, please provide source data in a data step with datalines.

ed_sas_member
Meteorite | Level 14

Hi @NOMBUH 

 

You can do that in a data step using an array:

proc sql noprint;
	select max(total) into: max_obs from (select count(*) as total from table1 group by Name);
quit;

data table2;
	set table1;
	by Name;
	
 	array Code_(&max_obs) $ /* Add $ if Code is a character variable */;
 	array Amount_(&max_obs) $ /* Add $ if Code is a character variable */;
 	
 	if first.Name then do;
		counter=0;
		call missing(of Code_(*));
		call missing(of Amount_(*));
	end;
	
 	counter+1;
 	
 	retain Code_;
 	retain Amount_;

 	
 	do i=1 to &max_obs;
		Code_(counter)=Code;
		Amount_(counter)=Amount;
	end;
	
	if last.Name then output;
	drop Code Amount counter i;

run;

You can also use a proc transpose, as suggested by @Kurt_Bremser :

 

proc transpose data=table1 out=table1_tr_code (drop=_name_) prefix=Code_;
	var Code;
	by Name;
run;

proc transpose data=table1 out=table1_tr_amount (drop=_name_) prefix=Amount_;
	var Amount;
	by Name;
run;

data table2;
	merge table1_tr_code table1_tr_amount;
	by Name;
run;

 

NOMBUH
Calcite | Level 5

Thank you very much 🙂 🙂 

ed_sas_member
Meteorite | Level 14
You're welcome!
Could you please mark the topic as answered?
Thank you 🙂
NOMBUH
Calcite | Level 5

Data Table_1;
Input Name$ code$ Amount;
cards;
John 2 100
John 6 500
Lucia 8 250
Josh 1 1000
Josh 2 980
Tim 1 1244
Tim 2 1470
;

run;

Ksharp
Super User
Data Table_1;
Input Name$ code$ Amount;
cards;
John 2 100
John 6 500
Lucia 8 250
Josh 1 1000
Josh 2 980
Tim 1 1244
Tim 2 1470
;

run;

proc sql noprint;
select max(n) into : n
 from ( select count(*) as n from table_1 group by name );
quit;
proc summary data=table_1 nway;
class name;
output out=want idgroup(out[&n] (code amount)=);
run;

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
  • 6 replies
  • 1308 views
  • 1 like
  • 4 in conversation