我有以下数据框架:
>head(d)
Smed Time TTFB
1 186 2014-03-19 20:13:00 6
2 196 2014-03-19 21:23:00 0
3 186 2014-03-19 19:33:00 22
4 186 2014-03-19 14:43:00 134
5 186 2014-03-19 23:53:00 36
> str(d)
$ Smed : Factor w/ 71 levels "1033","1038",..: 14 16 14 14 14 14 47 14 14 68 ...
$ Time : POSIXct, format: "2014-03-19 20:13:00" "2014-03-19 20:13:00" "2014-03-19 20:13:00" "2014-03-19 20:13:00" ...
$ TTFB : int 6 0 22 134 36 96 61 37 28 19 ...
如何与POSIXct时间格式进行时间比较,以获得18:13和23:20之间的数据
POSIXct
理解<
和>
,所以您只需这样做:
set.seed(1)
d <- data.frame(Time=as.POSIXct("2014-03-19")+24*60*60*runif(100))
index <- as.POSIXct("2014-03-19 18:00:00")<=d$Time &
d$Time<=as.POSIXct("2014-03-19 23:20:00")
d[index,]
试试
start <- as.POSIXct("2014-03-19 18:13:00")
end <- as.POSIXct("2014-03-19 23:10:00")
d[start < d$Time & d$Time < end, ]
希望有所帮助