gpt4 book ai didi

正则表达式只匹配到第一次出现类匹配

转载 作者:行者123 更新时间:2023-12-02 02:00:30 30 4
gpt4 key购买 nike

我正在寻找构建一个正则表达式来帮助我识别匹配的第一次出现。

我当前的正则表达式是 "(.*)[Cc][Aa][Ss][Ee][^a-zA-Z\\d]*(\\d\\d*)[^a-zA-Z\\d]*(.*)"
我想要做的是查找输入字符串是否包含单词“case”(不区分大小写),后跟任意数量的特殊字符,后跟一个数字;
我想检索文本的 3 部分。
假设我的输入字符串是 "RE: FW: case:-1234: there is some description"使用这个正则表达式,我可以检索,"RE: FW: " , "1234" , "there is some description" .

这很好,但如果我的输入字符串是"RE: FW: case:-1234: This is in reference to case 789 reopening"然后我的正则表达式返回,"RE: FW: case:-1234: This is in reference to" , "789" , "reopening" .

我想得到的是"RE: FW: " , "1234" , "This is in reference to case 789 reopening" .

我是正则表达式的新手,因此非常感谢任何帮助。

注意:我正在开发基于 Java 的工具,因此与 Java 兼容的正则表达式会很好。

最佳答案

您的正则表达式是否必须匹配整个字符串(即它是否使用 matches )?如果没有(或者如果您可以选择使用 find),只需删除 (.*) ,因为这就是将您的比赛推回去的原因:

[Cc][Aa][Ss][Ee][^a-zA-Z\\d]*(\\d\\d*)[^a-zA-Z\\d]*

否则,使领先的重复非贪婪;
(.*?)[Cc][Aa][Ss][Ee][^a-zA-Z\\d]*(\\d\\d*)[^a-zA-Z\\d]*(.*)

顺便说一下,您可以使用不区分大小写的匹配来简化这一点。如果您无法在您的工具中激活它,您可以在正则表达式中内联:
(?i)(.*?)case[^a-z\\d]*(\\d+)[^a-z\\d]*(.*)

请注意,我还简化了数字。 +表示出现 1 次或多次。

关于正则表达式只匹配到第一次出现类匹配,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17466927/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com