I want to create a new column in a data.table calculated from the current value of one column and the previous of another. Is it possible to access previous rows?
E.g.:
> DT <- data.table(A=1:5, B=1:5*10, C=1:5*100) > DT    A  B   C 1: 1 10 100 2: 2 20 200 3: 3 30 300 4: 4 40 400 5: 5 50 500 > DT[, D := C + BPreviousRow] # What is the correct code here? The correct answer should be
> DT    A  B   C   D 1: 1 10 100  NA 2: 2 20 200 210 3: 3 30 300 320 4: 4 40 400 430 5: 5 50 500 540 With shift() implemented in v1.9.6, this is quite straightforward. 
DT[ , D := C + shift(B, 1L, type="lag")] # or equivalently, in this case, DT[ , D := C + shift(B)] From NEWS:
- New function
shift()implements fastlead/lagof vector, list, data.frames or data.tables. It takes atypeargument which can be either "lag" (default) or "lead". It enables very convenient usage along with:=orset(). For example:DT[, (cols) := shift(.SD, 1L), by=id]. Please have a look at?shiftfor more info.
See history for previous answers.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With