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

Hi

I'm trying to adjust my dataset as follows:

The "before" dataset below is a sample from my existing dataset; the "after" is where I want it to be. Basically, the vehicle_years field is populated in the first entry of each year and then if there is a change over the year the change is given; all other entries are 0. I want (for each policy and each year) to cumulate the initial figure over each following transaction in the same year.     

data before;
infile datalines dlm=',';
input policy_no  year  vehicle_nos 5. ;
datalines ;
123,2010,1233
123,2010,1
123,2010,0
123,2011,1234
123,2011,0
123,2011,1
123,2011,0
123,2011,4
123,2012,1234
123,2012,0
123,2012,1
124,2010,12345
124,2010,0
124,2010,0
124,2011,12445
124,2011,0
124,2011,1
124,2012,13444
124,2012,0
124,2012,0
run;


data after;
infile datalines dlm=',';
input policy_no  year  vehicle_nos 5. ;
datalines ;
123,2010,1233
123,2010,1234
123,2010,1234
123,2011,1234
123,2011,1234
123,2011,1235
123,2011,1235
123,2011,1239
123,2012,1234
123,2012,1234
123,2012,1235
124,2010,12345
124,2010,12345
124,2010,12345
124,2011,12345
124,2011,12345
124,2011,12346
124,2012,13444
124,2012,13444
124,2012,13444
run;

1 ACCEPTED SOLUTION

Accepted Solutions
Kurt_Bremser
Super User

data after (drop=vno);

set before (rename=(vehicle_nos=vno));

by policy_no year;

retain vehicle_nos;

if first.year

then vehicle_nos = vno;

else vehicle_nos = vehicle_nos + vno;

run;

View solution in original post

1 REPLY 1
Kurt_Bremser
Super User

data after (drop=vno);

set before (rename=(vehicle_nos=vno));

by policy_no year;

retain vehicle_nos;

if first.year

then vehicle_nos = vno;

else vehicle_nos = vehicle_nos + vno;

run;

hackathon24-white-horiz.png

2025 SAS Hackathon: There is still time!

Good news: We've extended SAS Hackathon registration until Sept. 12, so you still have time to be part of our biggest event yet – our five-year anniversary!

Register Now

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
  • 1 reply
  • 1070 views
  • 0 likes
  • 2 in conversation