如何使用grep()/ gsub()来查找完全匹配

Adr*_*ian 54 regex grep r word-boundary gsub

string = c("apple", "apples", "applez")
grep("apple", string)
Run Code Online (Sandbox Code Playgroud)

这将为我提供所有三个元素的索引string.但我希望在单词"apple"上完全匹配(即我只想grep()返回索引1).

Avi*_*Raj 93

使用\b与单词和非单词字符之间匹配的单词边界,

string = c("apple", "apples", "applez")
grep("\\bapple\\b", string)
[1] 1
Run Code Online (Sandbox Code Playgroud)

要么

使用锚点.^断言我们刚开始.$断言我们到底是谁.

grep("^apple$", string)
[1] 1
Run Code Online (Sandbox Code Playgroud)

您可以将正则表达式存储在变量中,然后像下面一样使用它.

pat <- "\\bapple\\b"
grep(pat, string)
[1] 1
pat <- "^apple$"
grep(pat, string)
[1] 1
Run Code Online (Sandbox Code Playgroud)

更新:

paste("^",pat,"$", sep="")
[1] "^apple$"
string
[1] "apple"   "apple:s" "applez" 
pat
[1] "apple"
grep(paste("^",pat,"$", sep=""), string)
[1] 1
Run Code Online (Sandbox Code Playgroud)

  • `paste0("^",pat,"$")`在`paste`上保存了一些输入字符.不需要`sep =""` (2认同)

Ric*_*ven 26

对于精确匹配,使用起来最有意义==.此外,这将更快grep(),并且显然更容易.

which(string == "apple")
# [1] 1
Run Code Online (Sandbox Code Playgroud)