我有类似的数据:
dt <- structure(list(fct = structure(c(1L, 2L, 3L, 4L, 3L, 4L, 1L, 2L, 3L, 1L, 2L, 3L, 2L, 3L, 4L), .Label = c("a", "b", "c", "d"), class = "factor"), X = c(2L, 4L, 3L, 2L, 5L, 4L, 7L, 2L, 9L, 1L, 4L, 2L, 5L, 4L, 2L)), .Names = c("fct", "X"), class = "data.frame", row.names = c(NA, -15L))
我想根据fct
变量中的值从此数据框中选择行。例如,如果我希望选择包含“ a”或“ c”的行,则可以这样做:
dt[dt$fct == 'a' | dt$fct == 'c', ]
产生
1 a 2
3 c 3
5 c 5
7 a 7
9 c 9
10 a 1
12 c 2
14 c 4
如预期的那样。但是我的实际数据更复杂,我实际上想基于矢量(例如
vc <- c('a', 'c')
所以我尝试了
dt[dt$fct == vc, ]
但是当然不行。我知道我可以编写一些代码来遍历向量,然后拉出所需的行并将其附加到新的数据帧中,但是我希望有一种更优雅的方法。
那么如何根据向量的内容过滤/细分数据vc
呢?
dt[dt$fct %in% vc,]
基本上==
是用于一项,%in%
并且用于向量比较。