如果我有以下数据框:

value    factorA    factorB
1           a          e
2           a          f
3           a          g
1           b          k
2           b          l
3           b          m
1           c          e
2           c          g

我如何为每个factorA获得最高值以及与之相关联的factorB条目,即
value   factorA factorB

3         a        g
3         b        m
2         c        g

不先使用就可以吗
blocks<-split(factorA, list(), drop=TRUE)

然后对每个块$ a进行排序,因为这将被执行很多次,并且块的数量总是会改变。

最佳答案

这是使用基本R函数的一个选项:

maxRows <- by(df, df$factorA, function(X) X[which.max(X$value),])
do.call("rbind", maxRows)
#   value factorA factorB
# a     3       a       g
# b     3       b       m
# c     2       c       g

09-08 09:11