采用以下正则表达式:/^[^abc]/。这将匹配字符串开头的任何单个字符,a、b或c除外。
如果在其后面添加*–/^[^abc]*/–正则表达式将继续向结果中添加每个后续字符,直到它满足a、b或c。
例如,对于源字符串“qwerty qwerty whatever abc hello”,表达式将匹配到“qwerty-qwerty wh”。
但如果我希望匹配的字符串是“qwerty qwerty whatever”呢?
换句话说,我如何将所有内容都匹配到(但不包括)精确的序列“abc”?
采用以下正则表达式:/^[^abc]/。这将匹配字符串开头的任何单个字符,a、b或c除外。
如果在其后面添加*–/^[^abc]*/–正则表达式将继续向结果中添加每个后续字符,直到它满足a、b或c。
例如,对于源字符串“qwerty qwerty whatever abc hello”,表达式将匹配到“qwerty-qwerty wh”。
但如果我希望匹配的字符串是“qwerty qwerty whatever”呢?
换句话说,我如何将所有内容都匹配到(但不包括)精确的序列“abc”?
当前回答
我相信你需要子表达式。子表达式可以使用普通()括号。
本部分来自grep手册:
反向引用和子表达式后引用\n(其中n是一个数字)与子字符串匹配之前由正则表达式。
做类似于^[^(abc)]的事情应该会奏效。
其他回答
你需要看看断言,比如.+?(?=abc)。
请参阅:零长度断言的前瞻性和滞后性
请注意[abc]与abc不同。在括号内,它不是一个字符串-每个字符只是一种可能性。在括号外,它成为字符串。
所以我不得不即兴发挥。。。过了一段时间,我终于找到了所需的正则表达式:
如您所见,我需要在“grp bps”文件夹之前最多一个文件夹,但不包括最后一个破折号。并且要求在“grp bps”文件夹之后至少有一个文件夹。
复制粘贴的文本版本(更改文本的“grp bps”):
.*\/grp-bps\/[^\/]+
在寻求帮助解决问题后,我以堆栈溢出问题结束,但我没有找到任何解决方法:(
对于Java中的正则表达式,我也相信在大多数正则表达式引擎中,如果您想包括最后一部分,这将起作用:
.+?(abc)
例如,在这行中:
I have this very nice senabctence
选择“abc”之前的所有字符,并包括abc。
使用正则表达式,结果将是:我有一个非常好的senabc
测试一下:https://regex101.com/r/mX51ru/1
您的问题没有指定后续的字符序列是否是可选的,但所有其他答案都假定序列总是给定的。所以这里有一个,如果序列是可选的。
例如,如果将代码匹配到像foo#这样的行注释。。。或foo//。。。,行注释本身可能是可选的,但可能仍然希望与前面的代码匹配。
在这种情况下,我会使用^(?:(?!abc)。)*(或行注释:^(?:(?!#)。)*或^(?:(?!\/\/).)*)。
说明:^标记行的开头。(?:)是一个非捕获组,因为常规组将额外捕获组中最后一个匹配的字母,这是我们不需要的。在组内,我们使用负前瞻(?!)和。,所以除了特定的序列之外,所有的东西都是匹配的。使用*重复0到无限次。如果只想匹配非空字符串,请改用+。
匹配从开始到“在ABC之前”或“行结束”(如果没有ABC)
(1) 如果字符串在任何地方都不包含ABC,则匹配整个字符串
(2) 与空字符串不匹配
(不检查带换行符的字符串)
^.+?(?=ABC|$)