在 R 中使用 stringr 的带有非捕获组的正则表达式

标签 regex r stringr

我正在尝试将非捕获组与 str_extract 一起使用来自 stringr 的函数包裹。下面是一个例子:

library(stringr)
txt <- "foo"
str_extract(txt,"(?:f)(o+)")

这返回
"foo"

虽然我希望它只会返回
"oo"

喜欢这篇文章:https://stackoverflow.com/a/14244553/3750030

我如何在 R 中使用非捕获组从返回值中删除组的内容,同时使用它进行匹配?

最佳答案

当您使用正则表达式时 (?:f)(o+)这不会捕获 但它肯定会匹配。

捕获的意思是存储在内存中进行反向引用,这样就可以用于同一字符串中的重复匹配或替换捕获的字符串。

like in this post: https://stackoverflow.com/a/14244553/3750030



你误解了那个答案。 非捕获 组并不意味着 不匹配。 它是在 $1 中捕获的(组 1)因为在它之前没有组。

如果您希望 只有 匹配假设 B 后跟 A 那么你应该使用 positive lookbehind像这样。

正则表达式: (?<=f)(o+)
说明:
  • (?<=f)这将寻找 f出现在以下标记后面,但 不匹配 .
  • (o+)这将匹配和 捕获为组 (此处为 $1)如果先前的条件为真。

  • Regex101 Demo

    关于在 R 中使用 stringr 的带有非捕获组的正则表达式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36237627/

    相关文章:

    java - 拆分字符串后,数组中的第一个元素是什么?

    javascript - 数字在字符串中重复次数不超过五次的正则表达式,例如联系电话

    r - 什么相当于 Stata 对 R 中白噪声的 portmanteau (Q) 测试?

    r - 条形图条走向错误的方向

    r - 按顺序填充/重新扩展缺失值,而不是插补

    r - 在字符串检测中处理空字符串

    r - 从文本字符串中获取字符串的唯一计数

    java - 正则表达式忽略两个字符串之间的字符?

    c++ - 在 C++ 中从正则表达式中排除子表达式

    r - str_replace 不会替换所有出现的内容,但是 gsub 会替换吗?