R:在一个日期加1个月

Din*_*air 11 r dataframe zoo xts r-rook-package

我希望得到a startDate和之间的日期顺序endDate加1个月startDate.即,如果startDate是2013-01-31并且endDate是2013-07-31,我希望看到这样的日期:

"2013-01-31""2013-02-28""2013-03-31""2013-04-30""2013-05-31""2013-06-30""2013-07-31"

我试过了 seq.Date(as.Date("2013-01-31"),by="month",length.out=7).但是这段代码的输出是这样的

> seq.Date(as.Date("2013-01-31"),by="month",length.out=7)
[1] "2013-01-31" "2013-03-03" "2013-03-31" "2013-05-01" "2013-05-31" "2013-07-01" "2013-07-31"
Run Code Online (Sandbox Code Playgroud)

那么,获得正确输出的最简单的解决方案是什么?

ial*_*alm 23

我必须使用R中的日期,并且我找到了日期数据中最有用的软件包之一lubridate.对于您的问题,您可以简单地执行以下操作:

require(lubridate)
# ymd function parses dates in year-month-day format
startDate <- ymd('2013-01-31')
# The %m+% adds months to dates without exceeding the last day
myDates <- startDate %m+% months(c(0:6))
Run Code Online (Sandbox Code Playgroud)

lubridate 还有许多其他功能的日期,我强烈建议看一看.


bar*_*nus 14

这是行不通的,因为R不知道该怎么处理这个月的最后一天:)所以我有简单的解决方案.做同样的但是使用下个月的第一天然后减去1:

    seq(as.Date("2013-02-1"),by="month",length.out=7)-1
[1] "2013-01-31" "2013-02-28" "2013-03-31" "2013-04-30" "2013-05-31" "2013-06-30" "2013-07-31"
Run Code Online (Sandbox Code Playgroud)