ECI*_*CII 2 r subset dataframe
我有大数据框,有不同数量的列和行.我想在数据帧中搜索给定向量的值,并删除与给定向量的值匹配的单元格行.我想把它作为一个函数,因为我必须在可变行和列的多个数据帧上运行它,我想要避免for循环.
例如
ff<-structure(list(j.1 = 1:13, j.2 = 2:14, j.3 = 3:15), .Names = c("j.1","j.2", "j.3"), row.names = c(NA, -13L), class = "data.frame")
Run Code Online (Sandbox Code Playgroud)
删除包含值的单元格的所有行 8,9,10
我想我可以使用ff[ !ff[,1] %in% c(8, 9, 10), ]或subset(ff, !ff[,1] %in% c(8,9,10) )
但是为了从数据集中删除所有值,我必须解析每一列(可能有一个for循环,我希望避免的东西).
还有其他(更清洁)的方式吗?
非常感谢
apply 你对每一行的测试:
keeps <- apply(ff, 1, function(x) !any(x %in% 8:10))
Run Code Online (Sandbox Code Playgroud)
它给出了一个布尔矢量.然后用它子集:
ff[keeps,]
j.1 j.2 j.3
1 1 2 3
2 2 3 4
3 3 4 5
4 4 5 6
5 5 6 7
11 11 12 13
12 12 13 14
13 13 14 15
>
Run Code Online (Sandbox Code Playgroud)