我想在xts数据集中进行单列操作.我有一个非常大的数据集,所以我删除了一些数据和日期.下面的数据集是使用excel计算的,只显示从开始和结束的一些数据.
Date a b c
- 0.023
- 0.021 0.0214830
- 0.014 0.0142940 0.021483
- 0.008 0.0081120 0.014294
- 0.003 0.0030240 0.008112
- 0.002 0.0020060 0.003024
- 0 0 0.002006
- 0 0 0
- 0 0 0
- 0 0 0
- 0.001 0.0010000 0
- 0.003 0.0030030 0.001
- 0.005 0.0050150 0.003003
- 0.001 0.0010050 0.005015
- 0 0 0.001005
- -0.001 -0.0010000 0
- 0.002 0.0019980 -0.001
- 0.003 0.0030060 0.001998
- . . .
- . . .
- . . .
- . . .
- . . .
- . . .
- . .
- 0.019 0.01938 0.02042
- 0.015 0.0152850 0.01938
- 0.013 0.0131950 0.015285
Run Code Online (Sandbox Code Playgroud)
在上面的数据集中, a是我的初始数据,用于计算b和c.b使用该论坛b2 =(a2*a1)+ a2进行计算, (eg:(0.021*0.023)+0.021=0.021483)并且通过将b向下移动一行c3 = b2来形成c.
我的问题是如何在R xts数据集中执行这些操作
如何在xts中向上移动列.下面的转换是d1 = a3
Date a d
- 0.023 0.014
- 0.021 0.008
- 0.014 0.003
- 0.008 0.002
- 0.003 0
- 0.002 0
- 0 0
- 0 0
- 0 0.001
- 0 0.003
- 0.001 0.005
- 0.003 0.001
- 0.005 0
- 0.001 -0.001
- 0 0.002
- -0.001 0.003
- 0.002 0.024
- 0.003 0.015
- . .
- . .
- . .
- . .
- . .
- . 0.019
- . 0.015
- 0.019 0.013
- 0.015 0
- 0.013 0
Run Code Online (Sandbox Code Playgroud)
我试过这种方法
shift <- function(x, n){
c(x[-(seq(n))], rep(NA, n))
}
d<-shift(df$a,2)
Run Code Online (Sandbox Code Playgroud)
但它给出了这个错误
try.xts(NA)出错:as.xts.logical(x,...,.RECLASS = TRUE)出错:order.by必须是'names()'或以其他方式指定
Pascal是正确的,你会这样做就像你在data.frame上操作一样.这是一个例子:
library(xts)
Ex <- xts(1:10, Sys.Date()+1:10)
names(Ex) <- "a"
Ex$b <- (Ex$a*lag(Ex$a))+Ex$a
Ex$c <- lag(Ex$b)
Run Code Online (Sandbox Code Playgroud)
以上产生以下内容:
## a b c
## 2015-12-25 1 NA NA
## 2015-12-26 2 4 NA
## 2015-12-27 3 9 4
## 2015-12-28 4 16 9
## 2015-12-29 5 25 16
## 2015-12-30 6 36 25
## 2015-12-31 7 49 36
## 2016-01-01 8 64 49
## 2016-01-02 9 81 64
## 2016-01-03 10 100 81
Run Code Online (Sandbox Code Playgroud)
要创建一个d1 = a3的列,只需将函数中的对象更改为矩阵即可正常工作.也许有人可以填补空白为什么,但至少它现在有效.
shift <- function(x, n){
xMat <- as.matrix(x)
c(xMat[-(seq(n))], rep(NA, n))
}
Ex$d <- shift(Ex$a, 2)
Run Code Online (Sandbox Code Playgroud)
这会产生:
## a b c d
## 2015-12-26 1 NA NA 3
## 2015-12-27 2 4 NA 4
## 2015-12-28 3 9 4 5
## 2015-12-29 4 16 9 6
## 2015-12-30 5 25 16 7
## 2015-12-31 6 36 25 8
## 2016-01-01 7 49 36 9
## 2016-01-02 8 64 49 10
## 2016-01-03 9 81 64 NA
## 2016-01-04 10 100 81 NA
Run Code Online (Sandbox Code Playgroud)