gpt4 book ai didi

c# - C# 中的正则表达式,负向后视中的表达式

转载 作者:太空宇宙 更新时间:2023-11-03 19:09:09 27 4
gpt4 key购买 nike

我正在尝试编写一个表达式来匹配前面有奇数个问号的单引号。

我找到了一个否定的后视表达式来匹配一个问号

pattern (?<!\?)'

aaa?'aaa match
aaa'aaaa not match
aaa??'aaa match --wrong

但我需要的是检测奇数个问号,而不是一个。
我试着把它写成 (?<!\?(??))'但它没有用。

我想要的结果是

aaa?'aaaa  match
aaa??'aaaa not match
aaa???'aaaa match
aaa????'aaaa not match
aaa?????'aaaa match

最佳答案

您要查找的正则表达式是 (?<=(^|[^?])(\?\?)*\?)' .

让我们打破回顾(我把它改成正面的):

(^|[^?]) not a question mark (possibly also start of string, i.e. nothing)
(\?\?)* any number of question mark pairs
\? a single question mark

因此,为了使报价匹配,必须以相反的顺序在其前面加上这些标记。应该清楚的是,对于某些 N >= 0,这会强制前面问号的数量恰好为 2N + 1。

关于c# - C# 中的正则表达式,负向后视中的表达式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22375138/

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