3

我有 3 个 xts 对象,它们的所有索引都是“日期”对象:

    > a
                  a
    1995-01-03 1.76
    1995-01-04 1.69
    > b
                  b
    1995-01-03 1.67
    1995-01-04 1.63
    > c
                   c
    1995-01-03 1.795
    1995-01-04 1.690

要验证索引是否相同:

    > index(a) == index(b)
    [1] TRUE TRUE
    > index(a) == index(c)
    [1] TRUE TRUE

现在我看到了这种奇怪的行为:

    > merge.xts(a,b)
                  a    b
    1995-01-03   NA 1.67
    1995-01-03 1.76   NA
    1995-01-04   NA 1.63
    1995-01-04 1.69   NA

虽然以下合并工作正常:

    > merge.xts(a,c)
                  a     c
    1995-01-03 1.76 1.795
    1995-01-04 1.69 1.690

我无法弄清楚这里可能发生了什么。任何的想法?

更新:

    > dput(a)
    structure(c(1.76, 1.69), .indexCLASS = "Date", .indexTZ = "", .CLASS = "xts", class = c("xts", 
    "zoo"), index = structure(c(789168240, 789254580), tzone = "", tclass = "Date"), .Dim = c(2L, 
    1L), .Dimnames = list(NULL, "a"))

    > dput(b)
    structure(c(1.67, 1.63), .indexCLASS = "Date", .indexTZ = "", .CLASS = "xts", class = c("xts", 
    "zoo"), index = c(789109200, 789195600), .Dim = c(2L, 1L), .Dimnames = list(
        NULL, "b"))

    > dput(c)
    structure(c(1.795, 1.69), .indexCLASS = "Date", .indexTZ = "", .CLASS = "xts", class = c("xts", 
    "zoo"), index = c(789109200, 789195600), .Dim = c(2L, 1L), .Dimnames = list(
        NULL, "c"))

实际上,问题在于索引不相同(如 验证.index(a) == .index(b))。转换为数字然后重新创建一个 xts 并重新计算asDate修复问题的日期。

这个对象是to.daily从 xts 的方法创建的。

4

2 回答 2

4

当然,这看起来很复杂,但原因是 Date 不精确。日历日内的任何内容都是相同的“日期

正如乔希所暗示的那样,在某个地方,您的数据是以不同的方式/来源创建的。我会尝试想出一种更好的方法来管理这种可变性——因为它不是一个纯粹的新问题。直到那时:

index(x) <- index(x) 

会成功的。为什么?

正如 Josh 所指出的,index(x)[no <-] 采用底层 POSIXtime_t表示并将其转换为日期(自纪元以来的天数)。通过替换原始索引index<-将“日期”转换回 POSIX 时间(Rtime_t中的 POSIXct,C 中)

 t1 <- Sys.time()
 t2 <- Sys.time()

 as.Date(t1) == as.Date(t2)
 #[1] TRUE

 t1 == t2
 #[1] FALSE


 x1 <- xts(1, t1)
 x2 <- xts(2, t2)


 indexClass(x1) <- "Date"
 indexClass(x2) <- "Date"
 cbind(x1,x2)
            ..1 ..2
 2011-10-06   1  NA
 2011-10-06  NA   2

 .index(cbind(x1,x2))
 [1] 1317925443 1317925447
 attr(,"tzone")
 [1] "America/Chicago"
 attr(,"tclass")
 [1] "Date"

 # ugly, ugly solution
 index(x1) <- index(x1)
 index(x2) <- index(x2)
 cbind(x1,x2)
            ..1 ..2
 2011-10-06   1   2
 .index(cbind(x1,x2))
 [1] 1317877200
于 2011-10-06T18:29:23.860 回答
3

您不能index()用来验证索引是否相同,因为它将索引转换为indexClass(). 用于.index获取原始数字索引,那么您可能会发现:

all(.index(a) == .index(b))  # is FALSE

您应该调查您的数据源以查看可能导致此问题的原因。要快速修复,请执行以下操作:

index(b) <- as.Date(index(b))
于 2011-10-06T18:11:21.750 回答