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

Hi folks, 

I have 2 datasets.

I would like to divide the rows from the first dataset /second based on the matching item/region:

eg Divide OUT audi AB by IN audi AB

so : 10/1 and 20/2


data Base1;
length metric $3 item $4 region $2;
input metric $ item $ region $ PY1 PY2 ;
datalines;
OUT audi AB 10 20
OUT audi ON 30 20
OUT BMW AB 50 20
OUT BMW ON 70 80
OUT BMW BC 90 100
;

data Base2;
length metric $3 item $4 region $2;
input metric $ item $ region $ PY1 PY2 ;
datalines;
IN audi AB 1 2
IN audi ON 3 2
IN BMW AB 5 2
IN BMW ON 7 8
IN BMW BC 9 10
;

 

Expected Output :

Div Audi AB 10 10

Div Audi ON 10 10

Div BMW AB 10 10 

IN BMW ON 10 10

IN BMW BC 10 10

 

 

Any ideas on how to achieve this?

1 ACCEPTED SOLUTION

Accepted Solutions
PeterClemmensen
Tourmaline | Level 20
data want(drop=rc in:);
   if _N_=1 then do;
      declare hash h(dataset:'Base2(rename=(PY1=inPY1 PY2=inPY2))');
      h.definekey('item', 'region');
      h.definedata('inPY1', 'inPY2');
      h.definedone();
   end;
   
   set Base1;
   inPY1=.; inPY2=.;

   rc=h.find();

   PY1=divide(PY1, inPY1);
   PY2=divide(PY2, inPY2);
run;

View solution in original post

4 REPLIES 4
Reeza
Super User

Merge the data sets first so that the values are in the same line and then do the division.

Merges in SAS
https://stats.idre.ucla.edu/sas/modules/match-merging-data-files-in-sas/

Creating new variables:
https://stats.idre.ucla.edu/sas/modules/creating-and-recoding-variables-in-sas/

 

Spoiler

@new_sas_user_4 wrote:

Hi folks, 

I have 2 datasets.

I would like to divide the rows from the first dataset /second based on the matching item/region:

eg Divide OUT audi AB by IN audi AB

so : 10/1 and 20/2


data Base1;
length metric $3 item $4 region $2;
input metric $ item $ region $ PY1 PY2 ;
datalines;
OUT audi AB 10 20
OUT audi ON 30 20
OUT BMW AB 50 20
OUT BMW ON 70 80
OUT BMW BC 90 100
;

data Base2;
length metric $3 item $4 region $2;
input metric $ item $ region $ PY1 PY2 ;
datalines;
IN audi AB 1 2
IN audi ON 3 2
IN BMW AB 5 2
IN BMW ON 7 8
IN BMW BC 9 10
;

 

Expected Output :

Div Audi AB 10 10

Div Audi ON 10 10

Div BMW AB 10 10 

IN BMW ON 10 10

IN BMW BC 10 10

 

 

Any ideas on how to achieve this?


PeterClemmensen
Tourmaline | Level 20
data want(drop=rc in:);
   if _N_=1 then do;
      declare hash h(dataset:'Base2(rename=(PY1=inPY1 PY2=inPY2))');
      h.definekey('item', 'region');
      h.definedata('inPY1', 'inPY2');
      h.definedone();
   end;
   
   set Base1;
   inPY1=.; inPY2=.;

   rc=h.find();

   PY1=divide(PY1, inPY1);
   PY2=divide(PY2, inPY2);
run;
new_sas_user_4
Quartz | Level 8

Thanks a lot for the solution!!

I want to understand declare hash/ definekey/definedata better ....Do you have any reference material I could read through to understand ? Highly appreciate the help!!

PeterClemmensen
Tourmaline | Level 20

I sure do 🙂

 

Obviously, use the Hash Object Documentation

 

If you really want to get an understanding of the hash object, get a hold of the book Data Management Solutions Using SAS® Hash Table Operations: A Business Intelligence Case Study.

 

Best of luck!

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
  • 4 replies
  • 1473 views
  • 0 likes
  • 3 in conversation