BookmarkSubscribeRSS Feed
☑ This topic is solved. Need further help from the community? Please sign in and ask a new question.
kindbe17
Fluorite | Level 6

I am tying to cat all values, but seems i am doing it wrong, could you please help me?

 

 

proc sql;
create table cars11 as
select make,
type,
Mean (horsepower) as Mean
From sashelp.cars
Group by make, type;
quit;

proc transpose data =new;
var Mean;
run;

data new1;
length MeanM $200.;
set new;
MeanM=strip(put(col1,best.))||","||strip(put(col2,best.));
run;

1 ACCEPTED SOLUTION

Accepted Solutions
yabwon
Onyx | Level 15

You can get it for example like this:

proc sql;
  create table cars11 as
  select make,type,Mean(horsepower) as Mean
  from sashelp.cars
  group by make,type
  ;
quit;

proc transpose data=cars11 out=means;
  var Mean;
run;

data means1;
  set means;
  length MeanM $ 32767;
  MeanM=catx(",", of COL:);
  keep MeanM;
run;

but as @PeterClemmensen wrote, I don't get why ?

 

If you try to use it in some sort `x IN (...)` condition in SQL, why not just use a subquery? (The only reason for such step would be that you can't pass the data in table and you have to push it in a code.)

 

Bart

_______________
Polish SAS Users Group: www.polsug.com and communities.sas.com/polsug

"SAS Packages: the way to share" at SGF2020 Proceedings (the latest version), GitHub Repository, and YouTube Video.
Hands-on-Workshop: "Share your code with SAS Packages"
"My First SAS Package: A How-To" at SGF2021 Proceedings

SAS Ballot Ideas: one: SPF in SAS, two, and three
SAS Documentation



View solution in original post

5 REPLIES 5
PeterClemmensen
Tourmaline | Level 20

Why do you want all mean values in a single observations?

 

kindbe17
Fluorite | Level 6

i need them but they must be separated with commas, 

pink_poodle
Barite | Level 11
MeanM = CATX(",", col1, col2, …, coln);
yabwon
Onyx | Level 15

You can get it for example like this:

proc sql;
  create table cars11 as
  select make,type,Mean(horsepower) as Mean
  from sashelp.cars
  group by make,type
  ;
quit;

proc transpose data=cars11 out=means;
  var Mean;
run;

data means1;
  set means;
  length MeanM $ 32767;
  MeanM=catx(",", of COL:);
  keep MeanM;
run;

but as @PeterClemmensen wrote, I don't get why ?

 

If you try to use it in some sort `x IN (...)` condition in SQL, why not just use a subquery? (The only reason for such step would be that you can't pass the data in table and you have to push it in a code.)

 

Bart

_______________
Polish SAS Users Group: www.polsug.com and communities.sas.com/polsug

"SAS Packages: the way to share" at SGF2020 Proceedings (the latest version), GitHub Repository, and YouTube Video.
Hands-on-Workshop: "Share your code with SAS Packages"
"My First SAS Package: A How-To" at SGF2021 Proceedings

SAS Ballot Ideas: one: SPF in SAS, two, and three
SAS Documentation



SAS Innovate 2025: Register Today!

 

Join us for SAS Innovate 2025, our biggest and most exciting global event of the year, in Orlando, FL, from May 6-9. Sign up by March 14 for just $795.


Register now!

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
  • 5 replies
  • 1017 views
  • 2 likes
  • 4 in conversation