采用以下正则表达式:/^[^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”?
当前回答
这将对正则表达式有意义。
确切的单词可以从以下regex命令中获得:
("(.*?)")/g
在这里,我们可以得到属于双引号内的全局准确单词。
例如,如果我们的搜索文本是
这是“双引号”单词的示例
然后我们会从那句话中得到“双引号”。
其他回答
所以我不得不即兴发挥。。。过了一段时间,我终于找到了所需的正则表达式:
如您所见,我需要在“grp bps”文件夹之前最多一个文件夹,但不包括最后一个破折号。并且要求在“grp bps”文件夹之后至少有一个文件夹。
复制粘贴的文本版本(更改文本的“grp bps”):
.*\/grp-bps\/[^\/]+
在寻求帮助解决问题后,我以堆栈溢出问题结束,但我没有找到任何解决方法:(
这将对正则表达式有意义。
确切的单词可以从以下regex命令中获得:
("(.*?)")/g
在这里,我们可以得到属于双引号内的全局准确单词。
例如,如果我们的搜索文本是
这是“双引号”单词的示例
然后我们会从那句话中得到“双引号”。
我想将sidyll的答案扩展到正则表达式的不区分大小写版本。
如果你想匹配abc/abc/abc。。。不区分大小写(我需要这样做),使用以下正则表达式。
.+?(?=(?i)abc)
说明:
(?i) - This will make the following abc match case insensitively.
正则表达式的另一种解释与sidyll指出的相同。
对于Java中的正则表达式,我也相信在大多数正则表达式引擎中,如果您想包括最后一部分,这将起作用:
.+?(abc)
例如,在这行中:
I have this very nice senabctence
选择“abc”之前的所有字符,并包括abc。
使用正则表达式,结果将是:我有一个非常好的senabc
测试一下:https://regex101.com/r/mX51ru/1
如果您希望捕获“abc”以下的所有内容:
/^(.*?)abc/
说明:
()捕获括号内的表达式,以便使用$1、$2等进行访问。
^匹配行首
.*匹配任何内容?非贪婪(匹配所需的最小字符数)-[1]
[1] 需要这样做的原因是,否则,在以下字符串中:
whatever whatever something abc something abc
默认情况下,正则表达式是贪婪的,这意味着它将尽可能匹配。因此/^.*abc/将匹配“whateverwhatever某物abc某物”。添加非贪婪量词?使正则表达式只匹配“无论什么”。