采用以下正则表达式:/^[^abc]/。这将匹配字符串开头的任何单个字符,a、b或c除外。

如果在其后面添加*–/^[^abc]*/–正则表达式将继续向结果中添加每个后续字符,直到它满足a、b或c。

例如,对于源字符串“qwerty qwerty whatever abc hello”,表达式将匹配到“qwerty-qwerty wh”。

但如果我希望匹配的字符串是“qwerty qwerty whatever”呢?

换句话说,我如何将所有内容都匹配到(但不包括)精确的序列“abc”?


当前回答

试试看:

.+?efg

查询:

select REGEXP_REPLACE ('abcdefghijklmn','.+?efg', '') FROM dual;

输出:

hijklmn

其他回答

这将对正则表达式有意义。

确切的单词可以从以下regex命令中获得:

("(.*?)")/g

在这里,我们可以得到属于双引号内的全局准确单词。

例如,如果我们的搜索文本是

这是“双引号”单词的示例

然后我们会从那句话中得到“双引号”。

对于Java中的正则表达式,我也相信在大多数正则表达式引擎中,如果您想包括最后一部分,这将起作用:

.+?(abc)

例如,在这行中:

I have this very nice senabctence

选择“abc”之前的所有字符,并包括abc。

使用正则表达式,结果将是:我有一个非常好的senabc

测试一下:https://regex101.com/r/mX51ru/1

我相信你需要子表达式。子表达式可以使用普通()括号。

本部分来自grep手册:

反向引用和子表达式后引用\n(其中n是一个数字)与子字符串匹配之前由正则表达式。

做类似于^[^(abc)]的事情应该会奏效。

匹配从开始到“在ABC之前”或“行结束”(如果没有ABC)

(1) 如果字符串在任何地方都不包含ABC,则匹配整个字符串

(2) 与空字符串不匹配

(不检查带换行符的字符串)

^.+?(?=ABC|$)

你需要看看断言,比如.+?(?=abc)。

请参阅:零长度断言的前瞻性和滞后性

请注意[abc]与abc不同。在括号内,它不是一个字符串-每个字符只是一种可能性。在括号外,它成为字符串。