如何否定整个正则表达式?

我有一个正则表达式,例如(ma |(t){1})。它匹配ma和t并且不匹配bla。

我想否定正则表达式,因此它必须匹配bla,而不是ma和t,通过添加一些东西到这个正则表达式。我知道我可以写bla,但实际的正则表达式更复杂。

使用负外观:(?!pattern)

正环境可用于断言模式匹配。负面的周转是相反的:它用于断言一个模式不匹配。一些香精支持断言;一些对后视等进行限制。

链接到regular-expressions.info

> Lookahead and Lookbehind Zero-Width Assertions
> Flavor comparison

也可以看看

> How do I convert CamelCase into human-readable names in Java?
> Regex for all strings not containing a string?
> A regex to match a substring that isn’t followed by a certain other substring.

更多例子

这些都是尝试为玩具问题提供正则表达式解决方案作为练习;如果你想学习各种可以使用环视(嵌套它们,使用它们捕获等)的方法,它们应该是有教育意义的:

> codingBat plusOut using regex
> codingBat repeatEnd using regex
> codingbat wordEnds using regex

相关文章

一、校验数字的表达式 1 数字:^[0-9]*$ 2 n位的数字:^d{n}$ 3 至少n位的数字:^d{n,}$ 4 m-n位的数字...
正则表达式非常有用,查找、匹配、处理字符串、替换和转换字符串,输入输出等。下面整理一些常用的正则...
0. 注: 不同语言中的正则表达式实现都会有一些不同。下文中的代码示例除特别说明的外,都是使用JS中的...
 正则表达式是从信息中搜索特定的模式的一把瑞士军刀。它们是一个巨大的工具库,其中的一些功能经常...
一、校验数字的表达式 数字:^[0-9]*$ n位的数字:^\d{n}$ 至少n位的数字:^\d{n,}$ m-n位的数...
\ 将下一字符标记为特殊字符、文本、反向引用或八进制转义符。例如,“n”匹配字符“n”。“\n...