我想创建一个计数变量,每个给定年份中Z == 0的人数。如下图所示:在R中创建一个条件计数变量
PersonID Year Z Count*
1 1990 0 1
2 1990 1 1
3 1990 1 1
4 1990 2 1
5 1990 1 1
1 1991 1 3
2 1991 0 3
3 1991 1 3
4 1991 0 3
5 1991 0 3
1 1992 NA 1
2 1992 2 1
3 1992 2 1
4 1992 0 1
5 1993 1 0
1 1993 1 0
2 1993 2 0
3 1993 NA 0
4 1993 1 0
5 1994 0 5
1 1994 0 5
2 1994 0 5
3 1994 0 5
4 1994 0 5
我看了看我以前的R-剧本,发现这个
library(dplyr)
sum_data <- data %>% group_by(PersonID) %>% summarise(Count = sum(Z, na.rm=T))
有人可以帮助我得到这个权利?计数变量基本上应该计算Z == 0的总人数,格式与上面所示的相同。谢谢!!
dput(data)
structure(list(PersonID = c(1L, 2L, 3L, 4L, 5L, 1L, 2L, 3L, 4L,
5L, 1L, 2L, 3L, 4L, 5L, 1L, 2L, 3L, 4L, 5L, 1L, 2L, 3L, 4L),
Year = c(1990L, 1990L, 1990L, 1990L, 1990L, 1991L, 1991L,
1991L, 1991L, 1991L, 1992L, 1992L, 1992L, 1992L, 1993L, 1993L,
1993L, 1993L, 1993L, 1994L, 1994L, 1994L, 1994L, 1994L),
Z = c(0L, 1L, 1L, 2L, 1L, 1L, 0L, 1L, 0L, 0L, NA, 2L, 2L,
0L, 1L, 1L, 2L, NA, 1L, 0L, 0L, 0L, 0L, 0L)), .Names = c("PersonID",
"Year", "Z"), class = "data.frame", row.names = c(NA, -24L))
你需要'mutate'而不是总结,你需要指定要计算'ž== 0'。 – Sotos
看到下面的答案后,我必须回答。因为我确信这是一个骗局,我会留下我的答案作为一个评论︰'data%>%group_by(Year)%>%mutate(count = sum(Z == 0,na.rm = TRUE))' – Sotos
@Sotos正确答案 - 非常感谢。让我知道如果这是一个dup,我会把它拿下来。 – Boris