在R中为一天的一部分创建非周末时间间隔向量
我有一个原始的观测数据集,只在工作日的早上6点到晚上9点之间每隔5分钟采集一次。这些没有用于绘图等的日期时间信息,因此我试图创建一个日期时间向量,将其添加到我的数据中。例如:在R中为一天的一部分创建非周末时间间隔向量,r,datetime,time-series,lubridate,R,Datetime,Time Series,Lubridate,我有一个原始的观测数据集,只在工作日的早上6点到晚上9点之间每隔5分钟采集一次。这些没有用于绘图等的日期时间信息,因此我试图创建一个日期时间向量,将其添加到我的数据中。例如: X425 X432 X448 1 0.07994814 0.1513559 0.1293103 2 0.08102852 0.1436480 0.1259074 对此 X425 X432 X448 2010-05-24 06:00 0.07994814 0.1513559 0.1293103 2010-05-24 06:0
X425 X432 X448
1 0.07994814 0.1513559 0.1293103
2 0.08102852 0.1436480 0.1259074
对此
X425 X432 X448
2010-05-24 06:00 0.07994814 0.1513559 0.1293103
2010-05-24 06:05 0.08102852 0.1436480 0.1259074
我的工作如下:
# using lubridate and xts
library(xts)
library(lubridate)
# sequence of 5 min intervals from 06:00 to 21:00
sttime <- hms("06:00:00")
intervals <- sttime + c(0:180) * minutes(5)
# sequence of days from 2010-05-24 to 2010-11-05
dayseq <- timeBasedSeq("2010-05-24/2010-11-05/d")
# add intervals to dayseq
dayPlusTime <- function(days, times) {
dd <- NULL
for (i in 1:2) {
dd <- c(dd,(days[i] + times))}
return(dd)
}
obstime <- dayPlusTime(dayseq, intervals)`
#使用lubridate和xts
图书馆(xts)
图书馆(lubridate)
#从06:00到21:00的5分钟间隔顺序
sttime其中一个问题是,当分钟数超过60
时,间隔向量不会改变hour
这里有一种方法可以做到这一点:
#create the interval vector
intervals<-c()
for(p in 6:20){
for(j in seq(0,55,by=5)){
intervals<-c(intervals,paste(p,j,sep=":"))
}
}
intervals<-c(intervals,"21:0")
#get the days
dayseq <- timeBasedSeq("2010-05-24/2010-11-05/d")
#concatenate everything and format to POSIXct at the end
obstime<-strptime(unlist(lapply(dayseq,function(x){paste(x,intervals)})),format="%Y-%m-%d %H:%M", tz="GMT")
#创建区间向量
区间Abase
备选方案:
# create some dummy dates
dates <- Sys.Date() + 0:14
# select non-weekend days
wd <- dates[as.integer(format(dates, format = "%u")) %in% 1:5]
# create times from 06:00 to 21:00 by 5 min interval
times <- format(seq(from = as.POSIXct("2015-02-18 06:00"),
to = as.POSIXct("2015-02-18 21:00"),
by = "5 min"),
format = "%H:%M")
# create all date-time combinations, paste, convert to as.POSIXct and sort
wd_times <- sort(as.POSIXct(do.call(paste, expand.grid(wd, times))))
#创建一些虚拟日期
日期