i中另一列的R data.table grepl列

时间:2018-02-06 18:39:59

标签: r data.table

当A列中的字符串在B列中时,我可以进行子集化吗?

示例:

x <- data.table(a=letters, y=paste0(letters,"x"))

x[grepl(a, y)]
x[like(y, a)]

两者都只返回第一行的一行data.table和以下警告:

Warning message:
In grepl(pattern, vector) :
  argument 'pattern' has length > 1 and only the first element will be used

我希望这会返回所有行。

2 个答案:

答案 0 :(得分:4)

以下代码将grepl应用于ay作为该行对的每一行。基本上,grepl的第一个参数不能是长度大于1的向量,因此需要基于循环或基于lapply的方法。

x[mapply(grepl, a, y), ]
#     a  y
#  1: a ax
#  2: b bx
#  3: c cx
#  4: d dx
#  5: e ex
#  6: f fx
#  7: g gx
#  8: h hx
#  9: i ix
# 10: j jx
# 11: k kx
# 12: l lx
# 13: m mx
# 14: n nx
# 15: o ox
# 16: p px
# 17: q qx
# 18: r rx
# 19: s sx
# 20: t tx
# 21: u ux
# 22: v vx
# 23: w wx
# 24: x xx
# 25: y yx
# 26: z zx
#     a  y

答案 1 :(得分:1)

另一种可能性是使用dplyr。类似的东西:

x <- data.table(a=letters, y=paste0(letters,"x"))

x %>% rowwise() %>%
  filter(grepl(a,y)) %>% as.data.frame()

    a  y
 1: a ax
 2: b bx
 3: c cx
 4: d dx
 5: e ex
 6: f fx
 7: g gx
 8: h hx
 9: i ix
........ so