正則的幾個(gè)基本概念
更新時(shí)間:2006年11月08日 00:00:00 作者:
經(jīng)??吹秸f正則的文章,但說的只是方法,卻很少有說以下幾個(gè)基本概念:
1.貪婪:+,*,?,{m,n}等默認(rèn)是貪婪匹配,即盡可能多匹配,也叫最大匹配
如果后面加上?,就轉(zhuǎn)化為非貪婪匹配,需要高版本支持
2.獲?。耗J(rèn)用(x|y)是獲取匹配,很多時(shí)候只是測(cè)試,不一定要求得到所匹配的數(shù)據(jù),尤其在嵌套匹配或大數(shù)據(jù)中就要用非獲取匹配(?:x|y),這樣提高了效率,優(yōu)化了程序。
3.消耗:默認(rèn)是消耗匹配,一般在預(yù)查中是非消耗匹配。
舉個(gè)例子,2003-2-8要變?yōu)?003-02-08
如果用/-(\d)-/第二次匹配將從8開始,從而只替換第一個(gè)2,錯(cuò)誤
如果用/-(\d)(?=-)/則第二次匹配從第二個(gè)-開始,即不消耗字符-
4.預(yù)查:js中分為正向預(yù)查和負(fù)向預(yù)查
如上面的(?=pattern)是正向預(yù)查,在任何匹配 pattern 的字符串開始處匹配查找字符串。還有(?!pattern)是負(fù)向預(yù)查,在任何不匹配 pattern 的字符串開始處匹配查找字符串。負(fù)向預(yù)查有時(shí)會(huì)用在對(duì)[^]的擴(kuò)充,[^]只是一些字符,而?!可以使整個(gè)字符串。
5.回調(diào):一般用在替換上,即根據(jù)不用的匹配內(nèi)容返回不用的替換值,從而簡(jiǎn)化了程序,需要高版本支持
6.引用:\num 對(duì)所獲取的第num個(gè)匹配的引用。
例如,'(.)\1\1' 匹配AAA型。'(.)(.)\2\1' 匹配ABBA型。
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁(yè)面才能執(zhí)行]
當(dāng)然還有很多,這些都只是基本的需要掌握的
遇到正則問題,一般可用以下兩種方法解決:
1.分類,即根據(jù)所有的可能列出各種情況,如2003以內(nèi)的數(shù)
0 0
1-999 [1-9]\d{0,2}
1000-1999 1\d{3}
2000-2003 200[0-3]
所以最后的匹配就是 (0|[1-9]\d{0,2}|1\d{3}|200[0-3])
2.分組,即將整句分為不同的最小單元,如'、%、_成雙出現(xiàn)
能成組的,即允許存在的,有
''
%% 如果是大于2的偶數(shù)個(gè)可細(xì)分為多個(gè)更小的2字符單元
__
[^'%_] 非以上字符
所以最后的匹配就是 ^(''|%%|__|[^'%_])*$
--------------------------------------------------------------------------------
replace + function 5.5+支持
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁(yè)面才能執(zhí)行]
1.貪婪:+,*,?,{m,n}等默認(rèn)是貪婪匹配,即盡可能多匹配,也叫最大匹配
如果后面加上?,就轉(zhuǎn)化為非貪婪匹配,需要高版本支持
2.獲?。耗J(rèn)用(x|y)是獲取匹配,很多時(shí)候只是測(cè)試,不一定要求得到所匹配的數(shù)據(jù),尤其在嵌套匹配或大數(shù)據(jù)中就要用非獲取匹配(?:x|y),這樣提高了效率,優(yōu)化了程序。
3.消耗:默認(rèn)是消耗匹配,一般在預(yù)查中是非消耗匹配。
舉個(gè)例子,2003-2-8要變?yōu)?003-02-08
如果用/-(\d)-/第二次匹配將從8開始,從而只替換第一個(gè)2,錯(cuò)誤
如果用/-(\d)(?=-)/則第二次匹配從第二個(gè)-開始,即不消耗字符-
4.預(yù)查:js中分為正向預(yù)查和負(fù)向預(yù)查
如上面的(?=pattern)是正向預(yù)查,在任何匹配 pattern 的字符串開始處匹配查找字符串。還有(?!pattern)是負(fù)向預(yù)查,在任何不匹配 pattern 的字符串開始處匹配查找字符串。負(fù)向預(yù)查有時(shí)會(huì)用在對(duì)[^]的擴(kuò)充,[^]只是一些字符,而?!可以使整個(gè)字符串。
5.回調(diào):一般用在替換上,即根據(jù)不用的匹配內(nèi)容返回不用的替換值,從而簡(jiǎn)化了程序,需要高版本支持
6.引用:\num 對(duì)所獲取的第num個(gè)匹配的引用。
例如,'(.)\1\1' 匹配AAA型。'(.)(.)\2\1' 匹配ABBA型。
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁(yè)面才能執(zhí)行]
當(dāng)然還有很多,這些都只是基本的需要掌握的
遇到正則問題,一般可用以下兩種方法解決:
1.分類,即根據(jù)所有的可能列出各種情況,如2003以內(nèi)的數(shù)
0 0
1-999 [1-9]\d{0,2}
1000-1999 1\d{3}
2000-2003 200[0-3]
所以最后的匹配就是 (0|[1-9]\d{0,2}|1\d{3}|200[0-3])
2.分組,即將整句分為不同的最小單元,如'、%、_成雙出現(xiàn)
能成組的,即允許存在的,有
''
%% 如果是大于2的偶數(shù)個(gè)可細(xì)分為多個(gè)更小的2字符單元
__
[^'%_] 非以上字符
所以最后的匹配就是 ^(''|%%|__|[^'%_])*$
--------------------------------------------------------------------------------
replace + function 5.5+支持
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁(yè)面才能執(zhí)行]
相關(guān)文章
php匹配網(wǎng)址的正則 幾乎可以匹配任何網(wǎng)址
php匹配網(wǎng)址的正則 幾乎可以匹配任何網(wǎng)址,需要的朋友可以參考下2013-05-05一個(gè)好用的正則匹配電話號(hào)手機(jī)號(hào)郵箱網(wǎng)址的方法
找到一個(gè)好用的正則匹配電話和手機(jī)號(hào)的方法,感謝,在這里分享一下2014-05-05asp.net中利用正則表達(dá)式判斷一個(gè)字符串是否為數(shù)字的代碼
asp.net中利用正則表達(dá)式判斷一個(gè)字符串是否為數(shù)字的代碼,需要的朋友可以參考下。2011-12-12JavaScript中正則表達(dá)式的概念與應(yīng)用
這篇文章主要介紹了JavaScript中正則表達(dá)式的概念與應(yīng)用的相關(guān)資料,需要的朋友可以參考下2017-10-10javascript 手機(jī)號(hào)碼正則表達(dá)式驗(yàn)證函數(shù)
隨著手機(jī)號(hào)碼段的不斷增加,以前網(wǎng)上的手機(jī)號(hào)碼驗(yàn)證函數(shù)都不能那么完美的支持了,這里腳本之家編輯特為大家準(zhǔn)備的一個(gè)簡(jiǎn)單的正則與手機(jī)驗(yàn)證的函數(shù)分析。2009-12-12正則表達(dá)式\d元字符(相對(duì)于數(shù)字0-9)
正則表達(dá)式\d元字符,\d元字符可以匹配數(shù)字字符,等價(jià)于[0-9],在實(shí)際應(yīng)用中還是比較常見的,主要是針對(duì)數(shù)字的處理2016-12-12