在 R 中筛选具有唯一组合的行

> df1 = data.frame(v1=c('a','a','c','x','y','z'),v2=c('b','c','a','y','z','y'),v3=c('c','b','b','z','x','x'))   v1 v2 v31  a  b  c2  a  c  b3  c  a  b4  x  y  z5  y  z  x6  z  y  x

期望的输出:

   v1 v2 v3   a  b  c    x  y  z

或者(顺序不重要)

   v1 v2 v3   c  a  b   z  y  x

我正在尝试在一个数据框中查找行的唯一组合。

我尝试过

unique(df[,c('v1','v2','v3'))

但是,我没有得到期望的输出。我的数据框包含多个组合,并且还包括NA。请帮助我。


回答:

以下方法适用于你的数据示例,我相信它也适用于更大的数据集。

inx <- !duplicated(apply(df1, 1, function(x) paste(sort(x), collapse = "")))df1[inx, ]  v1 v2 v31  a  b  c4  x  y  z

Related Posts

L1-L2正则化的不同系数

我想对网络的权重同时应用L1和L2正则化。然而,我找不…

使用scikit-learn的无监督方法将列表分类成不同组别,有没有办法?

我有一系列实例,每个实例都有一份列表,代表它所遵循的不…

f1_score metric in lightgbm

我想使用自定义指标f1_score来训练一个lgb模型…

通过相关系数矩阵进行特征选择

我在测试不同的算法时,如逻辑回归、高斯朴素贝叶斯、随机…

可以将机器学习库用于流式输入和输出吗?

已关闭。此问题需要更加聚焦。目前不接受回答。 想要改进…

在TensorFlow中,queue.dequeue_up_to()方法的用途是什么?

我对这个方法感到非常困惑,特别是当我发现这个令人费解的…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注