Подтвердить что ты не робот

Создание вектора всех дней между двумя датами

Есть ли простой способ в R для того, чтобы указать все действительные дни, которые произошли между двумя указанными датами? Например, мне нужны следующие входы:

itemizeDates(startDate="12-30-11", endDate="1-4-12")

Чтобы создать следующие даты:

"12-30-11" "12-31-11", "1-1-12", "1-2-12", "1-3-12", "1-4-12"

Я гибко отношусь к классам и форматированию дат, мне просто нужна реализация концепции.

4b9b3361

Ответ 1

Вы ищете seq

> seq(as.Date("2011-12-30"), as.Date("2012-01-04"), by="days")
[1] "2011-12-30" "2011-12-31" "2012-01-01" "2012-01-02" "2012-01-03"
[6] "2012-01-04"

Или вы можете использовать :

> as.Date(as.Date("2011-12-30"):as.Date("2012-01-04"), origin="1970-01-01")
[1] "2011-12-30" "2011-12-31" "2012-01-01" "2012-01-02" "2012-01-03"
[6] "2012-01-04"

Здесь функция для удовлетворения вашего конкретного запроса

itemizeDates <- function(startDate="12-30-11", endDate="1-4-12", 
                         format="%m-%d-%y") {
  out <- seq(as.Date(startDate, format=format), 
             as.Date(endDate, format=format), by="days")  
  format(out, format)
}

> itemizeDates(startDate="12-30-11", endDate="1-4-12")
[1] "12-30-11" "12-31-11" "01-01-12" "01-02-12" "01-03-12" "01-04-12"