我想使用filter()和str_detect()过滤数据框,匹配多个模式而不需要多次调用str_detect()函数。在下面的示例中,我想过滤数据框df
,只显示包含字母a
f
和o
的行。
df <- data.frame(numbers = 1:52, letters = letters)
df %>%
filter(
str_detect(.$letters, "a")|
str_detect(.$letters, "f")|
str_detect(.$letters, "o")
)
# numbers letters
#1 1 a
#2 6 f
#3 15 o
#4 27 a
#5 32 f
#6 41 o
我已尝试了以下内容
df %>%
filter(
str_detect(.$letters, c("a", "f", "o"))
)
# numbers letters
#1 1 a
#2 15 o
#3 32 f
并收到以下错误
警告信息:在stri_detect_regex(string,pattern,opts_regex = opts(pattern))中:较长的对象长度不是较短对象长度的倍数
str_detect()
的用途比我想象的更为有限。如果您想在长字符串列表中进行部分匹配,推荐使用哪个函数?回到grep
吗? - dhd