正则表达式,分组,找到最后一场比赛

我希望这个正则表达式

([A-Z]+)$

会选择这个例子中的最后一次出现:

AB.012.00.022ABC-1
AB.013.00.022AB-1
AB.014.00.022ABAB-1

但我没有比赛.如果我删除’$’我得到:

AB and ABC
AB and AB
AB and ABAB

我只想要最后一次出现(ABC / AB / ABAB).
“AB”.不应该返回匹配.怎么忽略它?像(^ ??)的东西

解决方法

要获得最后一次出现,只需使用正向前瞻,告诉正则表达式引擎匹配最后的最终符号:

([A-Z]+)(?=-\d+$)

你的正则表达式只是在字符串的末尾查找从A到Z的大写字母,但在AB.012.00.022ABC-1,AB.013.00.022AB-1和AB的末尾都没有大写字母. 014.00.022ABAB-1(它们都以-1结尾).如果你的字符串最后都是-1,你可以使用(?= – 1 $)前瞻.

demo

相关文章

正则替换html代码中img标签的src值在开发富文本信息在移动端...
正则表达式
AWK是一种处理文本文件的语言,是一个强大的文件分析工具。它...
正则表达式是特殊的字符序列,利用事先定义好的特定字符以及...
Python界一名小学生,热心分享编程学习。
收集整理每周优质开发者内容,包括、、等方面。每周五定期发...