Я использую lubridate и решил, что это будет так просто
ymd("2010-01-31")+months(0:23)
Но посмотри, что получишь. Это все запутано!
[1] "2010-01-31 UTC" "2010-03-03 UTC" "2010-03-31 UTC" "2010-05-01 UTC" "2010-05-31 UTC" "2010-07-01 UTC" "2010-07-31 UTC" "2010-08-31 UTC" "2010-10-01 UTC"
[10] "2010-10-31 UTC" "2010-12-01 UTC" "2010-12-31 UTC" "2011-01-31 UTC" "2011-03-03 UTC" "2011-03-31 UTC" "2011-05-01 UTC" "2011-05-31 UTC" "2011-07-01 UTC"
[19] "2011-07-31 UTC" "2011-08-31 UTC" "2011-10-01 UTC" "2011-10-31 UTC" "2011-12-01 UTC" "2011-12-31 UTC"
Затем я прочитал, как lubridate обслуживает такие явления, как интервал, продолжительность и период. Итак, хорошо, я понимаю, что месяц - это количество дней, определенное как (365 * 4 + 1) / 48 = 30,438 дней Поэтому я попытался стать умным и переписать его как
ymd("2010-01-31")+ as.period(months(0:23))
Но это только что дало ошибку.
Error in as.period.default(months(0:23)) :
(list) object cannot be coerced to type 'double'