我對這些數據有一個新的問題。因爲我的完整的數據具有這樣參考R中data.table中的上一行,條件爲
a=data.table(A=c(1:10),B=c(1,2,0,2,0,0,3,4,0,2),C=c(2,3,1,4,5,3,6,7,2,2),D=c(1,1,1,1,1,2,2,2,2,2))
# A B C D
# 1: 1 1 2 1
# 2: 2 2 3 1
# 3: 3 0 1 1
# 4: 4 2 4 1
# 5: 5 0 5 1
# 6: 6 0 3 2
# 7: 7 3 6 2
# 8: 8 4 7 2
# 9: 9 0 2 2
#10: 10 2 2 2
形式現在,我想創建一個新的列,其計算與B A倍數值的數量/衣櫃前一行C,只要B是不是0.例如,在第2行中,我可以計算D = 2 *(1/2)。但是,第4行必須是4 *(2/3),不能是4 *(0/1)。 我使用
a[, D:= {i1 <- (NA^!B)
list(A*shift(na.locf(i1*B))/shift(na.locf(i1*C)))},by=d]
由於Akrun昨天推薦。它不起作用,當我計算它的結果是這樣的
A B C d D
# 1: 1 1 2 1 NA
# 2: 2 2 3 1 1.000000
# 3: 3 0 1 1 2.000000
# 4: 4 2 4 1 2.666667
# 5: 5 0 5 1 2.500000
# 6: 6 0 3 2 NA
# 7: 7 3 6 2 3.500000
# 8: 8 4 7 2 4.571429
# 9: 9 0 2 2 5.142857
# 10: 10 2 2 2 NA
任何人都知道這裏的問題是什麼?錯誤是較長的對象長度不是較短的對象長度的倍數。
什麼將是d的第一個元素的輸出? – akrun
D的第一個元素的輸出是NA –