正则表达式实现匹配连续数字的方法
实现的要求如下:
纯数字 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]