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

Hi there,

 

Please see below is what I try to get:

ID visit  want  
01 30 0  
01 34 4  = 34-30
01 39 5 = 39-34
01 45 6 =  45-39
02 35 0 = 35-35
02 40 5 = 40-35
02 42 2 = 42-40
       

 

How to code in SAS to get the value in "want"?

any help will be very appriciate.

 

Thanks in advance!

1 ACCEPTED SOLUTION

Accepted Solutions
Jagadishkatam
Amethyst | Level 16

 

data have;
input ID 	visit;
cards;
01 	30 	
01 	34 	
01 	39 	
01 	45 	
02 	35 	
02 	40 	
02 	42 	
;

data want;
set have;
by id visit;
want=visit-lag(visit);
if first.id then want=0;
run;
Thanks,
Jag

View solution in original post

4 REPLIES 4
Jagadishkatam
Amethyst | Level 16

 

data have;
input ID 	visit;
cards;
01 	30 	
01 	34 	
01 	39 	
01 	45 	
02 	35 	
02 	40 	
02 	42 	
;

data want;
set have;
by id visit;
want=visit-lag(visit);
if first.id then want=0;
run;
Thanks,
Jag
ballardw
Super User

Minor change suggestion to @Jagadishkatam

data want;
   set have;
   by id;
   want = dif(visit);
   if first.id then want=0;
run;

The Dif function is the equivalent of : var- lag(var);

 

ursula
Pyrite | Level 9

Thanks so much!!

it's very helpful!

ursula
Pyrite | Level 9

Thank you so much for  your prompt solution response.

I appreciated it.

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