具有重叠日期的 10 天间隔

时间:2021-04-22 15:48:51

标签: r date lapply posixct

我有一个年度数据集,我想将其分成 10 天的时间间隔。例如,我想将 2010-12-26 子集到 2011-01-04 使用这些日期的 x 和 y 值创建一个家庭范围,然后在这种情况下获取接下来的 9 天以及子集数据之间的重叠日期将是 2011-01-04 (2011-01-04 to 2011-01-13)。有什么好的办法吗?

library(lubridate)
date <- rep_len(seq(dmy("26-12-2010"), dmy("20-01-2011"), by = "days"), 500)
df <- data.frame(date = date,
                 x = runif(length(date), min = 60000, max = 80000),
                 y = runif(length(date), min = 800000, max = 900000))

我用 10 个观察值将它们分开,但我不确定如何使它更具体地获得 10 天而不是 10 个观察值。

interval_10 <- lapply(
  seq(0, nrow(df), by = 10),
  function(k) df[max(k+1, 1):min(k + 10, nrow(df)), ]
)

谢谢

1 个答案:

答案 0 :(得分:1)

lapply 通过唯一的日期向量来完成这项工作:

t <- unique(date)[seq(from = 1, to = length(unique(date)), by = 9)]
interval_10 <- lapply(
  1:(length(t)-1),
  function(k) df %>% filter(date <= t[k+1], date >= t[k])
)
相关问题