- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个像这样的数据框:
> prova
sent weeknumber processed
1 100 1 1
2 23 1 0
3 254 1 1
4 321 2 0
5 1241 2 0
6 323 2 1
7 1221 3 1
structure(list(sent = c(100, 23, 254, 321, 1241, 323, 1221),
weeknumber = c(1, 1, 1, 2, 2, 2, 3), processed = c(1, 0,
1, 0, 0, 1, 1)), .Names = c("sent", "weeknumber", "processed"
), row.names = c(NA, -7L), class = "data.frame")
如果我想为 processed = 0 的行提取按周数发送的数量,我可以这样做:
aggregate(prova[prova$processed==0,]$sent, by=list(prova[prova$processed==0,]$weeknumber), FUN = sum)
Group.1 x
1 1 23
2 2 1562
如果我想提取 Sent by week number when processed = 1 的总和,我会这样做:
aggregate(prova[prova$processed==1,]$sent, by=list(prova[prova$processed==1,]$weeknumber), FUN = sum)
Group.1 x
1 1 354
2 2 323
3 3 1221
但是,我想找到一种始终具有相同结果长度的方法,即在 processed=0 的情况下,如下所示:
Group.1 x
1 1 23
2 2 1562
3 3 0 // this is the new row I'd like to add
如果我简单地传递可能周数的整个列表,我会得到:
aggregate(prova[prova$processed==0,]$sent, by=list(prova$weeknumber), FUN = sum)
Error in aggregate.data.frame(as.data.frame(x), ...) :
arguments must have same length
非常感谢任何提示/建议!
最佳答案
我们可以对 data.table
使用 if/else
条件。将 'data.frame' 转换为 'data.table' (setDT(prova)
),按 'weeknumber' 分组,如果
没有任何
code> 'processed' 中的 0 个值,返回 0 或 else
获取 'sent' 的 sum
,其中 'processed' 为 0。
library(data.table)
setDT(prova)[, .(sent = if(!any(processed==0)) 0
else sum(sent[processed==0])), by = weeknumber]
# weeknumber sent
#1: 1 23
#2: 2 1562
#3: 3 0
但是,如果我们需要按“周数”分组的每个“已处理”值的“已发送”的总和
,一个方便的选项是dcast
dcast(setDT(prova), weeknumber~processed, value.var="sent", sum)
# weeknumber 0 1
#1: 1 23 354
#2: 2 1562 323
#3: 3 0 1221
或者使用 base R
中的 xtabs
,它还对“weeknumber”和“处理'。
xtabs(sent~weeknumber + processed, prova)
如果我们使用aggregate
,一个选项是merge
aggregate
的输出与unique
集合'weeknumber' 然后将 'sent' 中的 NA
元素替换为 0。
res <- merge(data.frame(weeknumber = unique(prova$weeknumber)),
aggregate(sent~weeknumber, prova, subset = processed ==0, FUN = sum),
all.x=TRUE)
res$sent[is.na(res$sent)] <- 0
res
# weeknumber sent
#1 1 23
#2 2 1562
#3 3 0
关于r - 如何聚合数据框并为未找到的类别添加 0,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40364620/
例如,我有一个父类Author: class Author { String name static hasMany = [ fiction: Book,
代码如下: dojo.query(subNav.navClass).forEach(function(node, index, arr){ if(dojo.style(node, 'd
我有一个带有 Id 和姓名的学生表和一个带有 Id 和 friend Id 的 Friends 表。我想加入这两个表并找到学生的 friend 。 例如,Ashley 的 friend 是 Saman
我通过互联网浏览,但仍未找到问题的答案。应该很容易: class Parent { String name Child child } 当我有一个 child 对象时,如何获得它的 paren
我正在尝试创建一个以 Firebase 作为我的后端的社交应用。现在我正面临如何(在哪里?)找到 friend 功能的问题。 我有每个用户的邮件地址。 我可以访问用户的电话也预订。 在传统的后端中,我
我主要想澄清以下几点: 1。有人告诉我,在 iOS 5 及以下版本中,如果您使用 Game Center 设置多人游戏,则“查找 Facebook 好友”(如与好友争夺战)的功能不是内置的,因此您需要
关于redis docker镜像ENTRYPOINT脚本 docker-entrypoint.sh : #!/bin/sh set -e # first arg is `-f` or `--some-
我是一名优秀的程序员,十分优秀!