1.([\s\S]*?)和(.*?)
.点 |
匹配除“\n”和"\r"之外的任何单个字符。要匹配包括“\n”和"\r"在内的任何字符,请使用像“[\s\S]”的模式。 |
* |
匹配前面的子表达式任意次。例如,zo*能匹配“z”,也能匹配“zo”以及“zoo”。*等价于{0,}。 |
? |
匹配前面的子表达式零次或一次。例如,“do(es)?”可以匹配“do”或“does”。?等价于{0,1}。 |
\s |
\s匹配任意的空白符,包括空格,制表符(Tab),换行符,中文全角空格 |
\S |
\S则是任意不是空白符的字符 |
这三个组合在一起的含义就是 :0个或者任意个不是\n的任意字符(非贪婪模式,发现一个就立即匹配结束)。([\s\S]*?)和(.*?)二者的差别就是后者没有匹配空白符的字符。
?涉及到贪婪模式
当正则表达式中包含能接受重复的限定符时,通常的行为是(在使整个表达式能得到匹配的前提下)匹配尽可能多的字符。以这个表达式为例:a.*b,它将会匹配最长的以a开始,以b结束的字符串。如果用它来搜索aabab的话,它会匹配整个字符串aabab。这被称为贪婪匹配。
有时,我们更需要懒惰匹配,也就是匹配尽可能少的字符。前面给出的限定符都可以被转化为懒惰匹配模式,只要在它后面加上一个问号?。这样.*?就意味着匹配任意数量的重复,但是在能使整个匹配成功的前提下使用最少的重复。现在看看懒惰版的例子吧:
a.*?b匹配最短的,以a开始,以b结束的字符串。如果把它应用于aabab的话,它会匹配aab(第一到第三个字符)和ab(第四到第五个字符)
2.\d
这个正则匹配数字他只能一次匹配一个数字0-9,无法匹配二位数字以上的,所以你如果要匹配二位数以上的可以这样写:/^(\d)*$/或者/^[0-9]*$/,他是无法分辨[1-188]他会将他当成从1-1 和 8 和8 这样分辨的。匹配1-188的话可以写成/^(1?[0-8]{1}[0-8]{1})?$/