如何编写正则表达式以匹配任何不符合特定模式的字符串?我面临的情况是我必须匹配(A和~B)模式.
您可以使用前瞻声明:
(?!999)\d{3}
此示例匹配除以外的三个数字999
.
但是如果您没有使用此功能的正则表达式实现(请参阅正则表达式风格的比较),您可能必须自己构建具有基本功能的正则表达式.
仅具有基本语法的兼容正则表达式将是:
[0-8]\d\d|\d[0-8]\d|\d\d[0-8]
这也匹配任何三位数序列999
.
如果要匹配字符串中的单词A而不匹配单词B.例如:如果您有文本:
1. I have a two pets - dog and a cat 2. I have a pet - dog
如果你想搜索有宠物狗的文本行而且没有猫,你可以使用这个正则表达式:
^(?=.*?\bdog\b)((?!cat).)*$
它只会找到第二行:
2. I have a pet - dog
匹配模式并使用宿主语言反转匹配的布尔结果.这将更易读和可维护.
没有,复活这个古老的问题,因为它有一个没有提到的简单解决方案.(在为正则表达式赏金任务做一些研究时找到你的问题.)
我面临的情况是我必须匹配(A和~B)模式.
这个基本的正则表达式非常简单: B|(A)
您只需忽略整体匹配并检查第1组捕获,其中包含A.
一个例子(所有关于在正则表达式中解析html的免责声明):A是数字,B是数字
正则表达式:
演示(查看右下方窗格中的第1组)
参考
如何匹配模式除了情况s1,s2,s3
除非......如何匹配模式