gpt4 book ai didi

regex - 有没有办法根据以前的捕获组匹配正则表达式,而不是以前捕获的?

转载 作者:行者123 更新时间:2023-12-04 13:43:34 25 4
gpt4 key购买 nike

好的,所以任务是有一个字符串可以看起来像 post,或者 post put 甚至 get put post .所有这些都必须匹配。最好不要匹配 [space]postget[space] 之类的偏差。

目前我想出了这个

^(post|put|delete|get)(( )(post|put|delete|get))*$

但是我对此并不满意,因为我不得不指定 (post|put|delete|get) 两次。它还匹配重复项,例如 post post

我想以某种方式对第一组使用反向引用(?),这样我就不必两次指定相同的条件。

但是,反向引用 \1 会帮助我匹配 post post,例如,这与我想要的相反。我想匹配第一个捕获组中以前在字符串中的单词。

这可能吗?我一直在查看 SO 问题,但我的 Google-fu 正在躲避我。

最佳答案

如果您使用基于 PCRE 的正则表达式引擎,您可以使用 subroutine calls(?n) 来递归子模式。

^(post|put|delete|get)( (?!\1)(?1))*$
^^^^

参见 regex demo

表达细节:

  • ^ - 字符串的开始
  • (post|put|delete|get) - 第 1 组匹配备选方案之一作为文字子串
  • ( (?!\1)(?1))* - 零个或多个序列:
    • - 一个空格
    • (?!\1) - negative lookahead如果当前位置之后的文本与由于 backreference 而捕获到组 1 中的文本相同,则匹配失败\1
    • (?1) - subroutine call到第一个捕获组(即它使用与第 1 组相同的模式)
  • $ - 字符串结尾

更新

为了避免匹配像 get post post 这样的字符串,您还需要在组 1 中添加一个负向先行,以便子例程调用知道我们没有想要匹配捕获到组 1 中的相同值。

^((post|put|delete|get)(?!.*\2))( (?1))*$

参见 regex demo

不同之处在于我们将交替捕获到组 2 并添加否定前瞻 (?!.*\2) 以禁止我们捕获的单词出现进一步在字符串中。 ( (?1))* 保持不变:现在,子例程使用前瞻性递归整个捕获组 1 子模式。

关于regex - 有没有办法根据以前的捕获组匹配正则表达式,而不是以前捕获的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38399245/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com