81

R で、指定された 2 つの日付の間に発生したすべての有効な日を箇条書きにする簡単な方法はありますか? たとえば、次の入力が必要です。

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"

私はクラスと日付のフォーマットに柔軟に対応しています。概念の実装が必要なだけです。

4

3 に答える 3

141

あなたが探しています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"
于 2013-01-22T02:02:56.017 に答える