我有類似於此一般滯後
User Date Value
A 2012-01-01 4
A 2012-01-02 5
A 2012-01-03 6
A 2012-01-04 7
B 2012-01-01 2
B 2012-01-02 3
B 2012-01-03 4
B 2012-01-04 5
我想創建的Value
滯後,尊重User
的數據集。
User Date Value Value.lag
A 2012-01-01 4 NA
A 2012-01-02 5 4
A 2012-01-03 6 5
A 2012-01-04 7 6
B 2012-01-01 2 NA
B 2012-01-02 3 2
B 2012-01-03 4 3
B 2012-01-04 5 4
我已經做到了非常低效的循環
df$value.lag1<-NA
levs<-levels(as.factor(df$User))
levs
for (i in 1:length(levs)) {
temper<- subset(df,User==as.numeric(levs[i]))
temper<- rbind(NA,temper[-nrow(temper),])
df$value.lag1[df$User==as.numeric(as.character(levs[i]))]<- temper
}
但是,這是非常緩慢的。我看過使用by
和tapply
,但沒有想出如何使他們工作。
我不認爲XTS或TS會因User元素而起作用。
有什麼建議嗎?
我認爲'plm'包有這種類型的數據的實現。 – Seb 2012-01-18 13:02:24