首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >根据R中的值删除行

根据R中的值删除行
EN

Stack Overflow用户
提问于 2021-02-09 22:28:16
回答 3查看 67关注 0票数 0

有没有办法根据值删除行?例如

代码语言:javascript
运行
复制
df
ColA   ColB
A      1
B      2    
A      3

预期输出(基本上我知道我们可以根据行号删除。但是有没有办法根据值来删除("A",3)

代码语言:javascript
运行
复制
df
ColA   ColB
A      1
B      2    
EN

回答 3

Stack Overflow用户

发布于 2021-02-09 22:38:20

你可以从基础R开始使用subset

代码语言:javascript
运行
复制
> subset(df,!(ColA=="A"&ColB==3))
  ColA ColB
1    A    1
2    B    2

data.table解决方案

代码语言:javascript
运行
复制
> setDT(df)[!.("A",3),on = .(ColA,ColB)]
   ColA ColB
1:    A    1
2:    B    2
票数 1
EN

Stack Overflow用户

发布于 2021-02-10 00:19:05

filter的一个选项

代码语言:javascript
运行
复制
library(dplyr)
df %>% 
    filter(!(ColA == "A" & ColB == 3))
票数 1
EN

Stack Overflow用户

发布于 2021-02-09 22:35:30

最简单的方法是使用which()函数(?which)。然后,您可以将其与减号一起使用,并基于特定条件对子集进行索引。

代码语言:javascript
运行
复制
df <- as.data.frame(cbind("ColA"=c("A", "B", "A"), "ColB" = c(1, 2, 3)))

df <- df[-which(df[,2]==3),]

View(df)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66120955

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档