【发布时间】:2014-03-09 06:09:48
【问题描述】:
一些示例数据.....
library(xts)
ref <- data.frame(Date = c("2/1/2000"))
frame <- read.table(text = " x Date Time
a 1/1/2000 5:00
a 1/1/2000 18:00
a 2/1/2000 7:00",
stringsAsFactors = FALSE,
header = TRUE
)
ref$Date <- as.POSIXct(ref$Date, format = "%d/%m/%Y")
frame$datetime <- paste(frame $Date,frame $Time, sep = " ")
frame$datetime <- as.POSIXct(frame $datetime, format = "%d/%m/%Y %H:%M")
frame <- xts(frame[, 1], order.by= frame [, 4] )
我可以使用匹配 ref 的帧中的所有天数..
> frame[ paste0(":", ref$Date) ]
[,1]
2000-01-02 07:00:00 "a" ]
以及之前的所有日子,包括使用
> frame[ paste0("::", ref$Date) ]
[,1]
2000-01-01 05:00:00 "a"
2000-01-01 18:00:00 "a"
2000-01-02 07:00:00 "a"
但如果我只想要前几天我做不到:
> frame[ !(paste0(ref$Date, "::")) ]
Error in !(paste0(ref$Date, "::")) : invalid argument type
问题
- 有没有一种简单的方法可以做到这一点?
- 不求助于
xts,如何仅使用 POSIXct 来做到这一点?
【问题讨论】:
标签: r time-series xts posixct