вы могли бы использовать такой подход ... он группируется по номерам недель ISO и дает минимальную / максимальную дату из выборочных данных для каждой группы. Вы можете изменить аргумент by
, чтобы получить нужные вам группы. например lubridate::epiweek()
, если вам нужны недели для начала в воскресенье, см. нижнюю часть.
- Сначала вам нужно вычислить дату начала первой недели и дату окончания на прошлой неделе (я предполагаю, что недели начинаются в понедельник, а для воскресенья см. нижнюю часть ответа).
- Создайте последовательность дней от начальной до конечной
- сгруппируйте по номеру недели, выберите минимальную и максимальную дату для каждая группа
начало недели в понедельник
library( data.table )
library( lubridate )
x <- as.Date("2020-01-01")
y <- as.Date("2020-03-31")
#assuming weeks start on a Monday
# calculate first date of starting week
start = x - lubridate::wday( x, week_start = 1) + 1
# calculate last date of ending week
end = y + 7 - lubridate::wday( y, week_start = 1 )
mydata <- data.table(
date = seq( start, end, by = "1 days" )
)
#group dates by ISO weeknumber, return min and max data
mydata[,
.( start = min(date), end = max(date) ),
by = .( weeknumber = lubridate::isoweek( date ) ) ]
# weeknumber start end
# 1: 1 2019-12-30 2020-01-05
# 2: 2 2020-01-06 2020-01-12
# 3: 3 2020-01-13 2020-01-19
# 4: 4 2020-01-20 2020-01-26
# 5: 5 2020-01-27 2020-02-02
# 6: 6 2020-02-03 2020-02-09
# 7: 7 2020-02-10 2020-02-16
# 8: 8 2020-02-17 2020-02-23
# 9: 9 2020-02-24 2020-03-01
# 10: 10 2020-03-02 2020-03-08
# 11: 11 2020-03-09 2020-03-15
# 12: 12 2020-03-16 2020-03-22
# 13: 13 2020-03-23 2020-03-29
# 14: 14 2020-03-30 2020-04-05
начало недели в воскресенье
start = x - lubridate::wday( x, week_start = 7) + 1 #!! <-- week_start = 7
# calculate last date of ending week
end = y + 7 - lubridate::wday( y, week_start = 7 ) #!! <-- week_start = 7
mydata <- data.table(
date = seq( start, end, by = "1 days" )
)
#group dates by ISO weeknumber, return min and max data
mydata[,
.( start = min(date), end = max(date) ),
by = .( weeknumber = lubridate::epiweek( date ) ) ] #!! <-- epiweek
# weeknumber start end
# 1: 1 2019-12-29 2020-01-04
# 2: 2 2020-01-05 2020-01-11
# 3: 3 2020-01-12 2020-01-18
# 4: 4 2020-01-19 2020-01-25
# 5: 5 2020-01-26 2020-02-01
# 6: 6 2020-02-02 2020-02-08
# 7: 7 2020-02-09 2020-02-15
# 8: 8 2020-02-16 2020-02-22
# 9: 9 2020-02-23 2020-02-29
# 10: 10 2020-03-01 2020-03-07
# 11: 11 2020-03-08 2020-03-14
# 12: 12 2020-03-15 2020-03-21
# 13: 13 2020-03-22 2020-03-28
# 14: 14 2020-03-29 2020-04-04