【问题标题】:remove rows if value matches that which was conditionally remove in r如果值与在 r 中有条件删除的值匹配,则删除行
【发布时间】:2019-11-25 10:05:54
【问题描述】:

我有一个数据框。我正在尝试删除列中的值与有条件删除的其他行匹配的行。让我提供一个简单的例子来更好地解释。

我尝试使用上一篇文章作为起点: Remove Rows From Data Frame where a Row match a String

>dat
A,B,C
4,3,Foo 
2,3,Bar
1,2,Bar
7,5,Zap

首先删除C列中带有“Foo”的行:

dat[!grepl("Foo", dat$C),]

现在我想删除 B 列中的值与 Foo 行中的值匹配的任何其他行。所以在这个例子中,任何 B = 3 的行都将被删除,因为第 1 行有 Foo,它被删除并且 B=3。

>dat.new
1,2,Bar
7,5,Zap

任何关于如何做到这一点的想法将不胜感激。

【问题讨论】:

    标签: r dataframe conditional-statements


    【解决方案1】:

    我们将“C”为“Foo”的“B”值子集,通过检查“B”中的这些值创建逻辑向量,取反(!)并创建“C”为不是“Foo”

    library(dplyr)
    dat.new <- dat %>%
                  filter(!B %in% B[C == 'Foo'], C != 'Foo')
    dat.new
    #  A B   C
    #1 1 2 Bar
    #2 7 5 Zap
    

    或者在base Rsubset

    subset(dat, !B %in% B[C == 'Foo'] & C != "Foo")
    

    数据

    dat <- structure(list(A = c(4L, 2L, 1L, 7L), B = c(3L, 3L, 2L, 5L), 
        C = c("Foo", "Bar", "Bar", "Zap")), row.names = c(NA, -4L
    ), class = "data.frame")
    

    【讨论】:

    • 哇,回复速度真快!工作得很好。也感谢您提供多种选择。