将PCRE中某些字符的总数限制为N

Restrict total number of certain characters in PCRE to N

本文关键字:PCRE 字符      更新时间:2023-10-16

是否有一种方法来编写这样一个正则表达式,它将匹配某个字符出现N次的字符串,或者在M到N次之间?字符可以分布在字符串的所有位置。这使得使用正则表达式变得困难。

我需要使用PCRE C/c++库。乍一看,它看起来不像正则表达式的正确工作,但对于字符串方法来说是微不足道的,但出于各种原因,我希望找到一个正则表达式解决方案。

我的第一个猜测是,我需要使用PCRE的callout特性来调用一个函数,该函数将计算捕获序列中字符C的出现次数,并接受或拒绝这样的匹配。还不确定callout功能是否可以这样使用

我认为下面的示例匹配包含3到5个x-es ^[^x]*(x[^x]*){3,5}[^x]*$的输入。

补充道:

讨论后比较好的是:^[^x]*(x[^x]*){3,5}$