有没有办法根据值删除行?例如
df
ColA   ColB
A      1
B      2    
A      3预期输出(基本上我知道我们可以根据行号删除。但是有没有办法根据值来删除("A",3)
df
ColA   ColB
A      1
B      2    发布于 2021-02-09 22:38:20
你可以从基础R开始使用subset
> subset(df,!(ColA=="A"&ColB==3))
  ColA ColB
1    A    1
2    B    2或data.table解决方案
> setDT(df)[!.("A",3),on = .(ColA,ColB)]
   ColA ColB
1:    A    1
2:    B    2发布于 2021-02-10 00:19:05
filter的一个选项
library(dplyr)
df %>% 
    filter(!(ColA == "A" & ColB == 3))发布于 2021-02-09 22:35:30
最简单的方法是使用which()函数(?which)。然后,您可以将其与减号一起使用,并基于特定条件对子集进行索引。
df <- as.data.frame(cbind("ColA"=c("A", "B", "A"), "ColB" = c(1, 2, 3)))
df <- df[-which(df[,2]==3),]
View(df)https://stackoverflow.com/questions/66120955
复制相似问题