【发布时间】:2019-04-08 16:53:19
【问题描述】:
我遇到了一个问题 - 如何对连续重复的奇数行求和并删除除第一行之外的所有行。我已经知道如何对连续重复行求和并删除除第一行之外的所有行(链接:https://stackoverflow.com/a/32588960/11323232)。但是这个项目,我想对连续重复的奇数行求和,而不是对所有连续重复的行求和。
ia<-c(1,1,2,NA,2,1,1,1,1,2,1,2)
time<-c(4.5,2.4,3.6,1.5,1.2,4.9,6.4,4.4, 4.7, 7.3,2.3, 4.3)
a<-as.data.frame(cbind(ia, time))
a
ia time
1 1 4.5
2 1 2.4
3 2 3.6
5 2 1.2
6 1 4.9
7 1 6.4
8 1 4.4
9 1 4.7
10 2 7.3
11 1 2.3
12 2 4.3
to
a
ia time
1 1 6.9
3 2 3.6
5 2 1.2
6 1 20.4
10 2 7.3
11 1 2.3
12 2 4.3
如何为我的目标编辑以下代码以求和连续重复的奇数行并删除除第一行以外的所有行?
result <- a %>%
filter(na.locf(ia) == na.locf(ia, fromLast = TRUE)) %>%
mutate(ia = na.locf(ia)) %>%
mutate(change = ia != lag(ia, default = FALSE)) %>%
group_by(group = cumsum(change), ia) %>%
# this part
summarise(time = sum(time))
【问题讨论】:
-
感谢 tmfmnk 和 Patrik_P。我有其他问题。如果“时间”是相同长度的列表。我该怎么做?比如时间
标签: r