2

我想创建一个单列,其日期/时间序列每小时增加一年或一个月(例如)。我正在使用这样的代码来生成这个序列:

start.date<-"2012-01-15"
start.time<-"00:00:00"
interval<-60 # 60 minutes
increment.mins<-interval*60 
x<-paste(start.date,start.time)

for(i in 1:365){
   print(strptime(x, "%Y-%m-%d %H:%M:%S")+i*increment.mins)
}

但是,我不确定如何指定日期和时间序列的范围。另外,我在处理第一个小时“00:00:00”时遇到了问题?不确定指定月份、年份等日期/时间序列长度的最佳方法是什么?任何建议将不胜感激。

4

2 回答 2

9

我强烈建议您使用POSIXct数据类型。这样您就可以seq毫无问题地使用这些数据,并根据需要使用这些数据。

start <- as.POSIXct("2012-01-15")
interval <- 60

end <- start + as.difftime(1, units="days")

seq(from=start, by=interval*60, to=end)

现在你可以用你的时间戳做任何你想做的事情。

于 2012-12-23T07:17:16.370 回答
1

试试这个。 mondate提前一个月非常聪明。例如,它将 1 月的最后一天提前到 2 月的最后一天,而其他日期/时间类往往会超过 3 月。 chron不使用时区,因此您无法像使用 POSIXct 那样获得编码的时区错误. 这x是问题。

library(chron)
library(mondate)

start.time.num <- as.numeric(as.chron(x))

# +1 means one month.  Use +12 if you want one year.
end.time.num <- as.numeric(as.chron(paste(mondate(x)+1, start.time)))

# 1/24 means one hour.  Change as needed.
hours <- as.chron(seq(start.time.num, end.time.num, 1/24))
于 2012-12-24T22:00:25.023 回答