根据重复遭遇添加新的日期字段[重复]

问题描述 投票:0回答:1

这个问题在这里已有答案:

我重复遇到了具有独特的IndIDII和独特的GPSSrl数的动物。每次遭遇都有一个FstCptr日期。

dat <- structure(list(IndIDII = c("BHS_115", "BHS_115", "BHS_372", "BHS_372", 
"BHS_372", "BHS_372"), GPSSrl = c("035665", "036052", "034818", 
"035339", "036030", "036059"), FstCptr = structure(c(1481439600, 
1450162800, 1426831200, 1481439600, 1457766000, 1489215600), class = c("POSIXct", 
"POSIXt"), tzone = "")), .Names = c("IndIDII", "GPSSrl", "FstCptr"
), class = "data.frame", row.names = c(1L, 2L, 29L, 30L, 31L, 
32L))

> dat
   IndIDII GPSSrl    FstCptr
1  BHS_115 035665 2016-12-11
2  BHS_115 036052 2015-12-15
29 BHS_372 034818 2015-03-20
30 BHS_372 035339 2016-12-11
31 BHS_372 036030 2016-03-12
32 BHS_372 036059 2017-03-11

对于每个IndID-GPSSrl分组,我想创建一个新的字段(NextCptr),记录下次遭遇的日期。对于最后一次遭遇,新字段将是NA,例如:

dat$NextCptr <- as.Date(c("2015-12-15", NA, "2016-12-11", "2016-03-12", "2017-03-11", NA))

> dat
   IndIDII GPSSrl    FstCptr   NextCptr
1  BHS_115 035665 2016-12-11 2015-12-15
2  BHS_115 036052 2015-12-15       <NA>
29 BHS_372 034818 2015-03-20 2016-12-11
30 BHS_372 035339 2016-12-11 2016-03-12
31 BHS_372 036030 2016-03-12 2017-03-11
32 BHS_372 036059 2017-03-11       <NA>

我想在dplyrgroup_by(IndIDII, GPSSrl)工作。

一如既往,非常感谢!

r dplyr lubridate
1个回答
1
投票

按列IndIDII分组然后使用leadFstCptr向前移动一个:

dat %>% group_by(IndIDII) %>% mutate(NextCptr = lead(FstCptr))

# A tibble: 6 x 4
# Groups:   IndIDII [2]
#  IndIDII GPSSrl             FstCptr            NextCptr
#    <chr>  <chr>              <dttm>              <dttm>
#1 BHS_115 035665 2016-12-11 02:00:00 2015-12-15 02:00:00
#2 BHS_115 036052 2015-12-15 02:00:00                  NA
#3 BHS_372 034818 2015-03-20 02:00:00 2016-12-11 02:00:00
#4 BHS_372 035339 2016-12-11 02:00:00 2016-03-12 02:00:00
#5 BHS_372 036030 2016-03-12 02:00:00 2017-03-11 02:00:00
#6 BHS_372 036059 2017-03-11 02:00:00                  NA

如果你需要向相反方向移动柱子,lag也可能有用,dat %>% group_by(IndIDII) %>% mutate(NextCptr = lag(FstCptr))

© www.soinside.com 2019 - 2024. All rights reserved.