正则表达式:(\w)((?=\1\1\1)(\1))+

这个正则表达式的意思是:匹配重复4次以上的字母数字,则匹配其剩下最后2位之前的部分。不太看得懂,麻烦哪位大神给个看的懂的详细解释,\w是任意一个字母与或数字或下划线字符,\1是反向引用,?=是预搜索不匹配,就是合起来不太看得懂。

比如字符串 aaaa
正则表达式:(\w)((?=\1\1\1)(\1))+

首先匹配的位置是第一个a,开始正则匹配,先是
(\w)匹配 第一个a成功,那么第一个子匹配的值就是a ,即 \1 的值为 a,现在匹配的位置是第二个a,继续往下匹配正则,
然后是 ((?=\1\1\1)(\1))+ 这一个整体,首先是 (?=\1\1\1),预测上面第一个匹配的a 后面要有 3个
a,预测成功,继续往下面执行正则(注意,现在的匹配的位置还是第二个a,预测不会改变匹配的位置),然后是 (\1), \1 的值为 a,所以第2个a匹配成功,现在的匹配的位置是第三个a,本次((?=\1\1\1)(\1))正则表达式匹配完成,由于是 +,要匹配((?=\1\1\1)(\1))一次以上,所以又开始执行(?=\1\1\1)正则,现在要预测上一次正则匹配成功的字符a后面要有3个a(也就是第二个a后面要有3个a),所有本次预测失败,不会进行匹配,那么结果为aa,追问

也就是说((?=\1\1\1)(\1))+的作用就是一直匹配到剩余不到三位,而且每次只匹配一位,对吗?

追答

((?=\1\1\1)(\1)) 作用是先预测后面有3位,如果有才再继续匹配一位,预测都失败了,就不会匹配在匹配一位了

温馨提示:内容为网友见解,仅供参考
第1个回答  2013-01-29
正则表达式 一般也就做表单验证的时候 需要JS验证格式规范什么的 你想要什么样的要求在网上查一查吧 我也工作快一年了 基本不怎么用 用到那个在百度查一下 应该都有 好多东西 会用就行了 不知道他是怎么做出来的来自:求助得到的回答
第1个回答  2013-01-29
^((?:(?!0)\d{1,3}(?:\.\d{1,2})?)|(?:0\.\d{1,2}?))$
相似回答