person_id  diag_date concept_id  event diff_prev_event
1:         1 2012-01-15    4265600 comorb         NA secs
2:         1 2012-01-15     201820 comorb          0 secs
3:         1 2012-03-15    4265600 comorb    5184000 secs
4:         2 2012-03-15     201820 comorb         NA secs
5:         2 2012-06-22     201820 comorb    8553600 secs
6:         2 2012-06-22    4265600 comorb          0 secs
I am trying to calculate the days since last event for each person. I am running into two issues.
- The time difference is showing in seconds. I need to get the days. (5184000 secs = 30 days)
- If two days are same dates then the 2nd one is showing 0 when it should be looking at the different date. Row 5 and 6 is same date so they would have the same date difference.
This is the code I tried:
dt[order(diag_date),diff_prev_event := difftime(diag_date, lag( diag_date)), by = c("person_id") ]
 
                        
Specify the
unitsThen, we grouped by 'person_id' and 'diag_date' and change the values to the
maxif there are more than one row-output
data