【发布时间】:2020-07-11 03:37:05
【问题描述】:
我有这个数据框,
`df <- tibble(
key = rep(1:3, c(8,4,5)),
Date = c(seq(as.Date('2016-12-17'), as.Date('2016-12-19'), '1 day'),
seq(as.Date('2016-12-21'), as.Date('2016-12-23'), '1 day'),
seq(as.Date('2016-12-29'), as.Date('2016-12-30'), '1 day'),
seq(as.Date('2017-05-18'), as.Date('2017-05-21'), '1 day'),
seq(as.Date('2017-05-18'), as.Date('2017-05-20'), '1 day'),
seq(as.Date('2017-05-23'), as.Date('2017-05-24'), '1 day')),
flag= c(1,1,1,0,1,1,0,1,1,1,1,1,1,1,1,0,1)
)`
对于每个“键”,我需要在“标志”第一次变为 0 之前的“日期”的最大值,或者如果“键”没有 0 标志,则返回“日期”的最大值。
我需要以下输出。
key Date flag
1 2016-12-19 1
2 2017-05-21 1
3 2017-05-20 1
有人可以帮我解决这个问题吗?
谢谢。
【问题讨论】:
标签: r dplyr dt date-arithmetic