我正在尝试编写一个正则表达式替换模式,以便替换散列中的数字,如下所示:
some_dict = {
TEST: 123
}
这样 123 就可以被捕获并替换。
(?<= |\t*[a-zA-Z0-9_]+: |\t+)\d+(?=.*)
但是,当我在 irb 中运行此 gsub 时,会发生以下情况:
irb(main):005:0> " TEST: 123".gsub(/(?<= |\t*[a-zA-Z0-9_]+: |\t+)\d+(?=.*)/, "321")
SyntaxError: (irb):5: invalid pattern in look-behind: /(?<= |\t*[a-zA-Z0-9_]+: |\t+)\d+(?=.*)/
我正在寻找类似的问题,例如 Invalid pattern in look-behind但我确保在我的后视中排除捕获组,所以我真的不确定问题出在哪里。
最佳答案
原因是 Ruby 的 Onigmo 正则表达式引擎不支持无限宽度的lookbehind 模式。
在一般情况下,包含像 *
这样的量词的正向回顾 , +
或{x,}
通常可以用后跟 \K
的消费模式代替:
/(?: |\t*[a-zA-Z0-9_]+: |\t+)\K\d+(?=.*)/
#^^^ ^^
但是,您甚至不需要那么复杂的模式。 (?=.*)
是多余的,因为它不需要任何东西,.*
甚至匹配空字符串。如果当前位置左侧紧邻空格或制表符,则将触发正向回顾模式。正则表达式等于
.gsub(/(?<=[ \t])\d+/, "321")
模式匹配的地方
-
(?<=[ \t])
- 紧邻空格/制表符的位置 -
\d+
- 一位或多位数字。
关于regex - 语法错误: (irb):4: invalid pattern in look-behind (positive look-behind/ahead),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67644969/