如何编写正则表达式来匹配任何不符合特定模式的字符串?我面临必须匹配 (A and ~B) 模式的情况。
8 回答
您可以使用前瞻断言:
(?!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 and ~B) 模式的情况。
基本的正则表达式非常简单:B|(A)
您只需忽略整体匹配并检查将包含 A 的第 1 组捕获。
一个例子(所有关于在正则表达式中解析 html 的免责声明):A 是数字,B 是内的数字<a tag
正则表达式:<a.*?<\/a>|(\d+)
演示(查看右下窗格中的第 1 组)
参考
(B)|(A)
然后使用第 2 组捕获的内容...
我在这里的回答也可能解决您的问题:
https://stackoverflow.com/a/27967674/543814
- 而不是替换,你会使用匹配。
- 而不是 group
$1
,您将阅读 group$2
。 - 组
$2
在此处不被捕获,这是您可以避免的。
例子:
Regex.Match("50% of 50% is 25%", "(\d+\%)|(.+?)");
第一个捕获组指定您希望避免的模式。最后一个捕获组捕获其他所有内容。只需读出该组,$2
.