首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >按组计算总样本和阳性样本

按组计算总样本和阳性样本
EN

Stack Overflow用户
提问于 2018-07-06 18:28:56
回答 1查看 46关注 0票数 2

我有这样的数据;

代码语言:javascript
复制
df <- data.frame(concentration=c(0,0,0,0,2,2,2,2,4,4,6,6,6),
             result=c(0,0,0,0,0,0,1,0,1,0,1,1,1))

我要计算每个浓度水平的结果总数。我想数数每个浓度水平的阳性样本的数量。我想要创建一个新的数据,集中水平,总结果,和积极的数字。

代码语言:javascript
复制
conc pos_c total_c
0    0     4
2    1     4
4    1     2
6    3     3

这就是我到目前为止使用plyr的想法;

代码语言:javascript
复制
c <- count(df, "concentration")
r <- count(df, "concentration","result")
names(c)[which(names(c) == "freq")] <- "total_c"
names(r)[which(names(r) == "freq")] <- "pos_c"
cbind(c,r)

  concentration total_c concentration pos_c
1             0       4             0     0
2             2       4             2     1
3             4       2             4     1
4             6       3             6     3

重复浓缩柱我想也许有更好/更容易的方法来做这件事,我错过了。也许是另一个图书馆。我不知道如何在R中这样做,这对我来说还是比较新的。谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-07-06 18:30:23

我们需要一个由sum组织的小组。使用tidyverse,我们按‘集中度(group_by)分组,然后由summarise获得逻辑表达式(result > 0)的两列- 1) sum,2)行数(n())。

代码语言:javascript
复制
library(dplyr)
df %>% 
  group_by(conc = concentration) %>% 
  summarise(pos_c = sum(result > 0), # in the example just sum(result) 
                    total_c = n())
# A tibble: 4 x 3
#   conc pos_c total_c
#  <dbl> <int>   <int>
#1     0     0       4
#2     2     1       4
#3     4     1       2
#4     6     3       3

或将base Rtableaddmargins结合使用

代码语言:javascript
复制
addmargins(table(df), 2)[,-1]
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51215958

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档