gpt4 book ai didi

r - 如何按组选择具有最小值并在R中包含NA的行

转载 作者:行者123 更新时间:2023-12-04 10:08:56 25 4
gpt4 key购买 nike

这是一个例子:

set.seed(123)    
data<-data.frame(X=rep(letters[1:3], each=4),Y=sample(1:12,12),Z=sample(1:100, 12))
data[data==3]<-NA

我要实现的是通过忽略 NAs 来选择具有最小 Y 的唯一行 X:

a 4 68
b 1 4
c 2 64

最好的方法是什么?

最佳答案

使用 data.table 包,这很简单:

library(data.table)

d <- data.table(data)
d[, min(Y, na.rm=TRUE), by=X]

您也可以使用 plyr 及其 ddply 功能:

library(plyr)

ddply(data, .(X), summarise, min(Y, na.rm=TRUE))

或者使用基础 R:

aggregate(X ~ ., data=data, FUN=min)

根据编辑,我肯定会使用 data.table:

d[, .SD[which.min(Y)], by=X]

但是,也有使用 base R 或其他包的解决方案。

关于r - 如何按组选择具有最小值并在R中包含NA的行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21046425/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com