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

Hello everyone, I'd like to ask if it's possible to do these in SAS.

Consider I have a data like this.

data have;
  input id column1-column2 ;
cards;
1 4000 3500
2 4500 3300
3 5000 3100
;

Can SAS do calculation for every value in column1 with every value in column2 and make it into a new table?
I want the result to look like this.

id column1 column2 difference
1 4000 3500 500
2 4000 3300 700
3 4000 3100 900
4 4500 3500 1000
5 4500 3300 1200
6 4500 3100 1400
7 5000 3500 1500
8 5000 3300 1700
9 5000 3100 1900
1 ACCEPTED SOLUTION

Accepted Solutions
PeterClemmensen
Tourmaline | Level 20

Try this

 

data want;
   set have(keep = id column1);
   do i = 1 to n;
      set have(keep = column2) point = i nobs = n;
      difference = column1 - column2;
      output;
   end;
run;

 

Result:

 

id  column1  column2  difference
1   4000     3500     500
1   4000     3300     700
1   4000     3100     900
2   4500     3500     1000
2   4500     3300     1200
2   4500     3100     1400
3   5000     3500     1500
3   5000     3300     1700
3   5000     3100     1900

 

View solution in original post

6 REPLIES 6
PeterClemmensen
Tourmaline | Level 20

Try this

 

data want;
   set have(keep = id column1);
   do i = 1 to n;
      set have(keep = column2) point = i nobs = n;
      difference = column1 - column2;
      output;
   end;
run;

 

Result:

 

id  column1  column2  difference
1   4000     3500     500
1   4000     3300     700
1   4000     3100     900
2   4500     3500     1000
2   4500     3300     1200
2   4500     3100     1400
3   5000     3500     1500
3   5000     3300     1700
3   5000     3100     1900

 

adilar39
Obsidian | Level 7
Thank you, it works really well.
ballardw
Super User

If the Id is not critical

proc sql;
   create table dif as
   select a.column1,b.column2, a.column1-b.column2 as diff
   from (select column1 from have) as a, (select column2 from have) as b
   ;
quit;
adilar39
Obsidian | Level 7
This also works well, thank you.
ChrisNZ
Tourmaline | Level 20

If you need the ID

proc sql;
   create table DIF as
   select monotonic() as ID
        , COLUMN1
        , COLUMN2
        , COLUMN1-COLUMN2 as DIF
   from HAVE(keep=COLUMN1) 
      , HAVE(keep=COLUMN2) 
   ;
quit;
ID column1  column2  DIFF
1 4000 3500 500
2 4000 3300 700
3 4000 3100 900
4 4500 3500 1000
5 4500 3300 1200
6 4500 3100 1400
7 5000 3500 1500
8 5000 3300 1700
9 5000 3100 1900
adilar39
Obsidian | Level 7
And this one also works well, thank you.

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
  • 1704 views
  • 3 likes
  • 4 in conversation