R-根据该行中另一列的特征选择一行

goo*_*101 3 r dataframe

所以我有以下data.frame

    num      id

1   44982   44979
2   44981   44979
3   43554   43551
4   43552   43551
5   42510   42507
6   42509   42507
7   41997   41994
8   41996   41994
9   40519   40517
10  40519   40517
11  40039   40036
12  40038   40036
13  31337   31335
14  31336   31335
15  31247   31245
16  31246   31245
17  43984   28769
18  28770   28769
19  27620   27618
20  27619   27618
Run Code Online (Sandbox Code Playgroud)

可以看出,"id"列中有重复项.我想要做的是根据"num"列中的最大值选择要保留的副本.因此,当在id列中重复执行重复项时,代码会查看num列,找到最高值行并删除最低值.输出应该看起来像这样.

        num      id

1       44982   44979
2       43554   43551
3       42510   42507
4       41997   41994
5       40519   40517
6       40039   40036
7       31337   31335
8       31247   31245
9       43984   28769
10      27620   27618
11      27497   27495
12      44317   27374
13      10892   10697
14      10612   10606
15      10445   10443
16      10361   10359
17      10063   10061
18      9673    9671
19      9601    9599
20      8148    8146
Run Code Online (Sandbox Code Playgroud)

在此先感谢您的帮助

Ren*_*rop 7

标准的R解决方案是:

aggregate(num~id, dat, max)
Run Code Online (Sandbox Code Playgroud)

结果:

      id   num
1  27618 27620
2  28769 43984
3  31245 31247
4  31335 31337
5  40036 40039
6  40517 40519
7  41994 41997
8  42507 42510
9  43551 43554
10 44979 44982
Run Code Online (Sandbox Code Playgroud)

您也可以data.table按如下方式使用:

require(data.table)
setDT(dat)[,.(num = max(num)),by=id]
setDF(dat) #making dat a normal data.frame again
Run Code Online (Sandbox Code Playgroud)

这将返回每个id的最高值num.