正则表达式实现匹配连续数字的方法


实现的要求如下:

纯数字 5-7位之间 前三位相同 从第四位开始连续

如下面的例子:

11123    #正确
22234    #正确
33345    #正确
333456   #正确
2223456   #正确
0001234   #正确
00012345  #错误:此行长度超标
000234   #错误:第3位与第4位不连续
111235   #错误:第5位和第6位不连续

1、匹配三位相同数字

(d)1{2}

2、匹配连续数字

匹配连续数字可以通过零宽断言来匹配,当然也没什么好办法,只能通过列举,如下两行都可以匹配3位连续数字

(0(?=1)|1(?=2)|2(?=3)|3(?=4)|4(?=5)|5(?=6)|6(?=7)|7(?=8)|8(?=9)){2}d
d((?<=0)1|(?<=1)2|(?<=2)3|(?<=3)4|(?<=4)5|(?<=5)6|(?<=6)7|(?<=7)8|(?<=8)9){2}

说明: 第一行采用正向零宽断言,第二行采用反向零宽断言

想了解更多关于正则表达式零宽断言的知识可以点击这里

结论

集合本题中的要求,由于要求相同前三,并且后面连续从第三位开始,完成正则如下:

^(d)1{2}((?<=(0(?=1)|1(?=2)|2(?=3)|3(?=4)|4(?=5)|5(?=6)|6(?=7)|7(?=8)|8(?=9)))d){2,4}$
^(d)1{2}((?<=0)1|(?<=1)2|(?<=2)3|(?<=3)4|(?<=4)5|(?<=5)6|(?<=6)7|(?<=7)8|(?<=8)9){2,4}$

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家学习或者使用正则表达式能带来一定的帮助,如果有疑问大家可以留言交流。

正则表达式简介及在C++11中的简单使用教程
正则表达式Regex(regularexpression)是一种强大的描述字符序列的工具。在许多语言中都存在着正则表达式,C++11中也将正则表达式纳入了新标准的一部分,不

正则表达式实现最小匹配功能的方法
本文实例讲述了正则表达式实现最小匹配功能的方法。分享给大家供大家参考,具体如下:正则表达式默认情况下实现的是最大化匹配,这在有些情况

手机号码验证方法(正则验证)
只允许输入数字xsl:attributename="onkeyup"value=value.replace(/[^d]/g,'')/xsl:attributexsl:attributename="onbeforepaste"clipboardData.setData('text',clipboardData.getData('text').replace(/[^d]