75

我有一个日期,我想添加几天以便找到未来的日期。

例如,我如何找到 2001 年 1 月 1 日之后 45 天的日期?

4

4 回答 4

118

使用 +

> as.Date("2001-01-01") + 45
[1] "2001-02-15"
于 2012-04-25T18:57:37.753 回答
52

你也可以使用

library(lubridate)
dmy("1/1/2001") + days(45)
于 2012-04-25T19:24:48.717 回答
13

除了其他人展示的简单加法外,还可以使用seq.Dateorseq.POSIXt求其他增量或减量(POSIXt 版本做秒、分、小时等):

> seq.Date( Sys.Date(), length=2, by='3 months' )[2]
[1] "2012-07-25"
于 2012-04-25T19:27:34.957 回答
13

只需使用

 as.Date("2001-01-01") + 45

来自基本 R,或许多贡献包之一中的日期功能。我的RcppBDT包包含来自 Boost Date_Time 的功能,包括给定月份中的“第三个星期三的日期”。

编辑:在@Andrie 的怂恿下,这里有更多来自RcppBDT的内容(实际上,这主要是 Rcpp 模块的测试用例)。

R> library(RcppBDT)
Loading required package: Rcpp
R> 
R> str(bdt)
Reference class 'Rcpp_date' [package ".GlobalEnv"] with 0 fields
 and 42 methods, of which 31 are possibly relevant:
   addDays, finalize, fromDate, getDate, getDay, getDayOfWeek, getDayOfYear, 
   getEndOfBizWeek, getEndOfMonth, getFirstDayOfWeekAfter,
   getFirstDayOfWeekInMonth, getFirstOfNextMonth, getIMMDate, getJulian, 
   getLastDayOfWeekBefore, getLastDayOfWeekInMonth, getLocalClock, getModJulian,
   getMonth, getNthDayOfWeek, getUTC, getWeekNumber, getYear, initialize, 
   setEndOfBizWeek, setEndOfMonth, setFirstOfNextMonth, setFromLocalClock,
   setFromUTC, setIMMDate, subtractDays
R> bdt$fromDate( as.Date("2001-01-01") )
R> bdt$addDays( 45 )
R> print(bdt)
[1] "2001-02-15"
R> 
于 2012-04-25T18:57:44.743 回答