正則表達式Collection

的字符:"^.{3}$"。
只能輸入由26個英文字母組成的字符串:"^[A-Za-z]+$"。
只能輸入由26個大寫英文字母組成的字符串:"^[A-Z]+$"。
只能輸入由26個小寫英文字母組成的字符串:"^[a-z]+$"。
只能輸入由數字和26個英文字母組成的字符串:"^[A-Za-z0-9]+$"。
只能輸入由數字、26個英文字母或者下劃線組成的字符串:"^\w+$"。
驗證用戶密碼:"^[a-zA-Z]\w{5,17}$"正確格式爲:以字母開頭,長度在6~18之間,只能包含字符、數字和下劃線。
驗證是否含有^%&',;=?$\"等字符:"[^%&',;=?$\x22]+"。
只能輸入漢字:"^[\u4e00-\u9fa5]{0,}$"
驗證Email地址:"^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$"。
驗證InternetURL:"^http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?$"。
驗證電話號碼:"^(\(\d{3,4}-)|\d{3.4}-)?\d{7,8}$"正確格式爲:"XXX-XXXXXXX"、"XXXX-XXXXXXXX"、"XXX-XXXXXXX"、"XXX-XXXXXXXX"、"XXXXXXX"和"XXXXXXXX"。
驗證身份證號(15位或18位數字):"^\d{15}|\d{18}$"。
驗證一年的12個月:"^(0?[1-9]|1[0-2])$"正確格式爲:"01"~"09"和"1"~"12"。
驗證一個月的31天:"^((0?[1-9])|((1|2)[0-9])|30|31)$"正確格式爲;"01"~"09"和"1"~"31"。
利用正則表達式限制網頁表單裏的文本框輸入內容:
用正則表達式限制只能輸入中文:onkeyup="value=value.replace(/[^\u4E00-\u9FA5]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\u4E00-\u9FA5]/g,''))"
用正則表達式限制只能輸入全角字符: onkeyup="value=value.replace(/[^\uFF00-\uFFFF]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\uFF00-\uFFFF]/g,''))"
用正則表達式限制只能輸入數字:onkeyup="value=value.replace(/[^\d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))"
用正則表達式限制只能輸入數字和英文:onkeyup="value=value.replace(/[\W]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))"
得用正則表達式從URL地址中提取文件名的javascript程序,以下結果爲page1
s=" http://www.9499.net/page1.htm"
s=s.replace(/(.*\/){0,}([^\.]+).*/ig,"$2")
alert(s)
匹配雙字節字符(包括漢字在內):[^\x00-\xff]
應用:計算字符串的長度(一個雙字節字符長度計2,ASCII字符計1)
String.prototype.len=function(){return this.replace([^\x00-\xff]/g,"aa").length;}
匹配空行的正則表達式:\n[\s| ]*\r
匹配HTML標記的正則表達式:/<(.*)>.*<\/\1>|<(.*) \/>/
匹配首尾空格的正則表達式:(^\s*)|(\s*$)
String.prototype.trim = function()
{
 

   return this.replace(/(^\s*)|(\s*$)/g, "");
}
利用正則表達式分解和轉換IP地址:
下面是利用正則表達式匹配IP地址,並將IP地址轉換成對應數值的Javascript程序:
function IP2V(ip)
{
re=/(\d+)\.(\d+)\.(\d+)\.(\d+)/g  //匹配IP地址的正則表達式
if(re.test(ip))
{
return RegExp.$1*Math.pow(255,3))+RegExp.$2*Math.pow(255,2))+RegExp.$3*255+RegExp.$4*1
}
else
{
throw new Error("Not a valid IP address!")
}
}
不過上面的程序若是不用正則表達式,而直接用split函數來分解可能更簡單,程序以下:
var ip="10.100.20.168"
ip=ip.split(".")
alert("IP值是:"+(ip[0]*255*255*255+ip[1]*255*255+ip[2]*255+ip[3]*1))
符號解釋:
字符
描述
\
將下一個字符標記爲一個特殊字符、或一個原義字符、或一個 向後引用、或一個八進制轉義符。例如,'n' 匹配字符 "n"。'\n' 匹配一個換行符。序列 '\\' 匹配 "\" 而 "\(" 則匹配 "("。
^
匹配輸入字符串的開始位置。若是設置了 RegExp 對象的 Multiline 屬性,^ 也匹配 '\n' 或 '\r' 以後的位置。
$
匹配輸入字符串的結束位置。若是設置了RegExp 對象的 Multiline 屬性,$ 也匹配 '\n' 或 '\r' 以前的位置。
*
匹配前面的子表達式零次或屢次。例如,zo* 能匹配 "z" 以及 "zoo"。* 等價於{0,}。
+
匹配前面的子表達式一次或屢次。例如,'zo+' 能匹配 "zo" 以及 "zoo",但不能匹配 "z"。+ 等價於 {1,}。
?
匹配前面的子表達式零次或一次。例如,"do(es)?" 能夠匹配 "do" 或 "does" 中的"do" 。? 等價於 {0,1}。
{n}
n 是一個非負整數。匹配肯定的 n 次。例如,'o{2}' 不能匹配 "Bob" 中的 'o',可是能匹配 "food" 中的兩個 o。
{n,}
n 是一個非負整數。至少匹配n 次。例如,'o{2,}' 不能匹配 "Bob" 中的 'o',但能匹配 "foooood" 中的全部 o。'o{1,}' 等價於 'o+'。'o{0,}' 則等價於 'o*'。
{n,m}
m 和 n 均爲非負整數,其中n <= m。最少匹配 n 次且最多匹配 m 次。例如,"o{1,3}" 將匹配 "fooooood" 中的前三個 o。'o{0,1}' 等價於 'o?'。請注意在逗號和兩個數之間不能有空格。
?
當該字符緊跟在任何一個其餘限制符 (*, +, ?, {n}, {n,}, {n,m}) 後面時,匹配模式是非貪婪的。非貪婪模式儘量少的匹配所搜索的字符串,而默認的貪婪模式則儘量多的匹配所搜索的字符串。例如,對於字符串 "oooo",'o+?' 將匹配單個 "o",而 'o+' 將匹配全部 'o'。
.
匹配除 "\n" 以外的任何單個字符。要匹配包括 '\n' 在內的任何字符,請使用象 '[.\n]' 的模式。
(pattern)
匹配 pattern 並獲取這一匹配。所獲取的匹配能夠從產生的 Matches 集合獲得,在VBScript 中使用 SubMatches 集合,在JScript 中則使用 $0…$9 屬性。要匹配圓括號字符,請使用 '\(' 或 '\)'。
(?:pattern)
匹配 pattern 但不獲取匹配結果,也就是說這是一個非獲取匹配,不進行存儲供之後使用。這在使用 "或" 字符 (|) 來組合一個模式的各個部分是頗有用。例如, 'industr(?:y|ies) 就是一個比 'industry|industries' 更簡略的表達式。
(?=pattern)
正向預查,在任何匹配 pattern 的字符串開始處匹配查找字符串。這是一個非獲取匹配,也就是說,該匹配不須要獲取供之後使用。例如,'Windows (?=95|98|NT|2000)' 能匹配 "Windows 2000" 中的 "Windows" ,但不能匹配 "Windows 3.1" 中的 "Windows"。預查不消耗字符,也就是說,在一個匹配發生後,在最後一次匹配以後當即開始下一次匹配的搜索,而不是從包含預查的字符以後開始。
(?!pattern)
負向預查,在任何不匹配 pattern 的字符串開始處匹配查找字符串。這是一個非獲取匹配,也就是說,該匹配不須要獲取供之後使用。例如'Windows (?!95|98|NT|2000)' 能匹配 "Windows 3.1" 中的 "Windows",但不能匹配 "Windows 2000" 中的 "Windows"。預查不消耗字符,也就是說,在一個匹配發生後,在最後一次匹配以後當即開始下一次匹配的搜索,而不是從包含預查的字符以後開始
x|y
匹配 x 或 y。例如,'z|food' 能匹配 "z" 或 "food"。'(z|f)ood' 則匹配 "zood" 或 "food"。
[xyz]
字符集合。匹配所包含的任意一個字符。例如, '[abc]' 能夠匹配 "plain" 中的 'a'。
[^xyz]
負值字符集合。匹配未包含的任意字符。例如, '[^abc]' 能夠匹配 "plain" 中的'p'。
[a-z]
字符範圍。匹配指定範圍內的任意字符。例如,'[a-z]' 能夠匹配 'a' 到 'z' 範圍內的任意小寫字母字符。
[^a-z]
負值字符範圍。匹配任何不在指定範圍內的任意字符。例如,'[^a-z]' 能夠匹配任何不在 'a' 到 'z' 範圍內的任意字符。
\b
匹配一個單詞邊界,也就是指單詞和空格間的位置。例如, 'er\b' 能夠匹配"never" 中的 'er',但不能匹配 "verb" 中的 'er'。
\B
匹配非單詞邊界。'er\B' 能匹配 "verb" 中的 'er',但不能匹配 "never" 中的 'er'。
\cx
匹配由 x 指明的控制字符。例如, \cM 匹配一個 Control-M 或回車符。x 的值必須爲 A-Z 或 a-z 之一。不然,將 c 視爲一個原義的 'c' 字符。
\d
匹配一個數字字符。等價於 [0-9]。
\D
匹配一個非數字字符。等價於 [^0-9]。
\f
匹配一個換頁符。等價於 \x0c 和 \cL。
\n
匹配一個換行符。等價於 \x0a 和 \cJ。
\r
匹配一個回車符。等價於 \x0d 和 \cM。
\s
匹配任何空白字符,包括空格、製表符、換頁符等等。等價於 [ \f\n\r\t\v]。
\S
匹配任何非空白字符。等價於 [^ \f\n\r\t\v]。
\t
匹配一個製表符。等價於 \x09 和 \cI。
\v
匹配一個垂直製表符。等價於 \x0b 和 \cK。
\w
匹配包括下劃線的任何單詞字符。等價於'[A-Za-z0-9_]'。
\W
匹配任何非單詞字符。等價於 '[^A-Za-z0-9_]'。
\xn
匹配 n,其中 n 爲十六進制轉義值。十六進制轉義值必須爲肯定的兩個數字長。例如,'\x41' 匹配 "A"。'\x041' 則等價於 '\x04' & "1"。正則表達式中可使用 ASCII 編碼。.
\num
匹配 num,其中 num 是一個正整數。對所獲取的匹配的引用。例如,'(.)\1' 匹配兩個連續的相同字符。
\n
標識一個八進制轉義值或一個向後引用。若是 \n 以前至少 n 個獲取的子表達式,則 n 爲向後引用。不然,若是 n 爲八進制數字 (0-7),則 n 爲一個八進制轉義值。
\nm
標識一個八進制轉義值或一個向後引用。若是 \nm 以前至少有 nm 個得到子表達式,則 nm 爲向後引用。若是 \nm 以前至少有 n 個獲取,則 n 爲一個後跟文字 m 的向後引用。若是前面的條件都不知足,若 n 和 m 均爲八進制數字 (0-7),則 \nm 將匹配八進制轉義值 nm。
\nml
若是 n 爲八進制數字 (0-3),且 m 和 l 均爲八進制數字 (0-7),則匹配八進制轉義值 nml。
\un
匹配 n,其中 n 是一個用四個十六進制數字表示的 Unicode 字符。例如, \u00A9 匹配版權符號 (?)。javascript

 

 

1。^\d+$  //匹配非負整數(正整數 + 0)
2。^[0-9]*[1-9][0-9]*$  //匹配正整數
3。^((-\d+)|(0+))$  //匹配非正整數(負整數 + 0)
4。^-[0-9]*[1-9][0-9]*$  //匹配負整數
5。^-?\d+$    //匹配整數
6。^\d+(\.\d+)?$  //匹配非負浮點數(正浮點數 + 0)
7。^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$  //匹配正浮點數
8。^((-\d+(\.\d+)?)|(0+(\.0+)?))$  //匹配非正浮點數(負浮點數 + 0)
9。^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$  //匹配負浮點數
10。^(-?\d+)(\.\d+)?$  //匹配浮點數
11。^[A-Za-z]+$  //匹配由26個英文字母組成的字符串
12。^[A-Z]+$  //匹配由26個英文字母的大寫組成的字符串
13。^[a-z]+$  //匹配由26個英文字母的小寫組成的字符串
14。^[A-Za-z0-9]+$  //匹配由數字和26個英文字母組成的字符串
15。^\w+$  //匹配由數字、26個英文字母或者下劃線組成的字符串
16。^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$    //匹配email地址
17。^[a-zA-z]+://匹配(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$  //匹配url
18。匹配中文字符的正則表達式: [\u4e00-\u9fa5]
19。匹配雙字節字符(包括漢字在內):[^\x00-\xff]
20。應用:計算字符串的長度(一個雙字節字符長度計2,ASCII字符計1)
String.prototype.len=function(){return this.replace([^\x00-\xff]/g,"aa").length;}
21。匹配空行的正則表達式:\n[\s| ]*\r
22。匹配HTML標記的正則表達式:/<(.*)>.*<\/\1>|<(.*) \/>/
23。匹配首尾空格的正則表達式:(^\s*)|(\s*$)
* 正則表達式用例
  * 一、^\S+[a-z A-Z]$ 不能爲空 不能有空格  只能是英文字母
  * 二、\S{6,}         不能爲空 六位以上
  * 三、^\d+$          不能有空格 不能非數字
  * 四、(.*)(\.jpg|\.bmp)$ 只能是jpg和bmp格式
  * 五、^\d{4}\-\d{1,2}-\d{1,2}$ 只能是2004-10-22格式
  * 六、^0$            至少選一項
  * 七、^0{2,}$        至少選兩項
  * 八、^[\s|\S]{20,}$ 不能爲空 二十字以上
  * 九、^\+?[a-z0-9](([-+.]|[_]+)?[a-z0-9]+)*@([a-z0-9]+(\.|\-))+[a-z]{2,6}$郵件
  * 十、\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*([,;]\s*\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*)* 輸入多個地址用逗號或空格分隔郵件
  * 十一、^(\([0-9]+\))?[0-9]{7,8}$電話號碼7位或8位或前面有區號例如(022)87341628
  * 十二、^[a-z A-Z 0-9 _]+@[a-z A-Z 0-9 _]+(\.[a-z A-Z 0-9 _]+)+(\,[a-z A-Z 0-9 _]+@[a-z A-Z 0-9 _]+(\.[a-z A-Z 0-9 _]+)+)*$
  *     只能是字母、數字、下劃線;必須有@和.同時格式要規範 郵件
  * 13 ^\w+@\w+(\.\w+)+(\,\w+@\w+(\.\w+)+)*$上面表達式也能夠寫成這樣子,更精練。
    14   ^\w+((-\w+)|(\.\w+))*\@\w+((\.|-)\w+)*\.\w+$java


匹配中文字符的正則表達式: [\u4e00-\u9fa5] 
評註:匹配中文還真是個頭疼的事,有了這個表達式就好辦了 
 
匹配雙字節字符(包括漢字在內):[^\x00-\xff] 
評註:能夠用來計算字符串的長度(一個雙字節字符長度計2,ASCII字符計1) 
 
匹配空白行的正則表達式:\n\s*\r 
評註:能夠用來刪除空白行 
 
匹配HTML標記的正則表達式: <(\S*?)[^>]*>.*? | <.*? /> 
評註:網上流傳的版本太糟糕,上面這個也僅僅能匹配部分,對於複雜的嵌套標記依舊無能爲力 
 
匹配首尾空白字符的正則表達式:^\s* |\s*$ 
評註:能夠用來刪除行首行尾的空白字符(包括空格、製表符、換頁符等等),很是有用的表達式 
 
匹配Email地址的正則表達式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)* 
評註:表單驗證時很實用 
 
匹配網址URL的正則表達式:[a-zA-z]+://[^\s]* 
評註:網上流傳的版本功能頗有限,上面這個基本能夠知足需求 
 
匹配賬號是否合法(字母開頭,容許5-16字節,容許字母數字下劃線):^[a-zA-Z][a-zA-Z0-9_]{4,15}$ 
評註:表單驗證時很實用 
 
匹配國內電話號碼:\d{3}-\d{8} |\d{4}-\d{7} 
評註:匹配形式如 0511-4405222 或 021-87888822 
 
匹配騰訊QQ號:[1-9][0-9]{4,} 
評註:騰訊QQ號從10000開始 
 
匹配中國郵政編碼:[1-9]\d{5}(?!\d) 
評註:中國郵政編碼爲6位數字 
 
匹配身份證:\d{15} |\d{18} 
評註:中國的身份證爲15位或18位 
 
匹配ip地址:\d+\.\d+\.\d+\.\d+ 
評註:提取ip地址時有用 
 
匹配特定數字: 
^[1-9]\d*$    //匹配正整數 
^-[1-9]\d*$   //匹配負整數 
^-?[1-9]\d*$   //匹配整數 
^[1-9]\d* |0$  //匹配非負整數(正整數 + 0) 
^-[1-9]\d* |0$   //匹配非正整數(負整數 + 0) 
^[1-9]\d*\.\d* |0\.\d*[1-9]\d*$   //匹配正浮點數 
^-([1-9]\d*\.\d* |0\.\d*[1-9]\d*)$  //匹配負浮點數 
^-?([1-9]\d*\.\d* |0\.\d*[1-9]\d* |0?\.0+ |0)$  //匹配浮點數 
^[1-9]\d*\.\d* |0\.\d*[1-9]\d* |0?\.0+ |0$   //匹配非負浮點數(正浮點數 + 0) 
^(-([1-9]\d*\.\d* |0\.\d*[1-9]\d*)) |0?\.0+ |0$  //匹配非正浮點數(負浮點數 + 0) 
評註:處理大量數據時有用,具體應用時注意修正 
 
匹配特定字符串: 
^[A-Za-z]+$  //匹配由26個英文字母組成的字符串 
^[A-Z]+$  //匹配由26個英文字母的大寫組成的字符串 
^[a-z]+$  //匹配由26個英文字母的小寫組成的字符串 
^[A-Za-z0-9]+$  //匹配由數字和26個英文字母組成的字符串 
^\w+$  //匹配由數字、26個英文字母或者下劃線組成的字符串 
"^[\\w-]+(+)*@[\\w-]+(\\.[\\w-]+)+___FCKpd___0quot]\\.[\\w-]+)*@[\\w-]+(\\.[\\w-]+)+___FCKpd___0quot;    //email地址   
"^[a-zA-z]+://(\\w+(-\\w+)*)(\\.(\\w+(-\\w+)*))*(\\?\\S*)?___FCKpd___0quot;  //url 
匹配中文字符的正則表達式: [\u4e00-\u9fa5]
評註:匹配中文還真是個頭疼的事,有了這個表達式就好辦了
匹配雙字節字符(包括漢字在內):[^\x00-\xff]
評註:能夠用來計算字符串的長度(一個雙字節字符長度計2,ASCII字符計1)
匹配空白行的正則表達式:\n\s*\r
評註:能夠用來刪除空白行
匹配HTML標記的正則表達式: <(\S*?)[^>]*>.*? | <.*? />
評註:網上流傳的版本太糟糕,上面這個也僅僅能匹配部分,對於複雜的嵌套標記依舊無能爲力
匹配首尾空白字符的正則表達式:^\s* |\s*$
評註:能夠用來刪除行首行尾的空白字符(包括空格、製表符、換頁符等等),很是有用的表達式
匹配Email地址的正則表達式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
評註:表單驗證時很實用
匹配網址URL的正則表達式:[a-zA-z]+://[^\s]*
評註:網上流傳的版本功能頗有限,上面這個基本能夠知足需求
匹配賬號是否合法(字母開頭,容許5-16字節,容許字母數字下劃線):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
評註:表單驗證時很實用
匹配國內電話號碼:\d{3}-\d{8} |\d{4}-\d{7}
評註:匹配形式如 0511-4405222 或 021-87888822
匹配騰訊QQ號:[1-9][0-9]{4,}
評註:騰訊QQ號從10000開始
匹配中國郵政編碼:[1-9]\d{5}(?!\d)
評註:中國郵政編碼爲6位數字
匹配身份證:\d{15} |\d{18}
評註:中國的身份證爲15位或18位
匹配ip地址:\d+\.\d+\.\d+\.\d+
評註:提取ip地址時有用
匹配特定數字:
^[1-9]\d*$    //匹配正整數
^-[1-9]\d*$   //匹配負整數
^-?[1-9]\d*$   //匹配整數
^[1-9]\d* |0$  //匹配非負整數(正整數 + 0)
^-[1-9]\d* |0$   //匹配非正整數(負整數 + 0)
^[1-9]\d*\.\d* |0\.\d*[1-9]\d*$   //匹配正浮點數
^-([1-9]\d*\.\d* |0\.\d*[1-9]\d*)$  //匹配負浮點數
^-?([1-9]\d*\.\d* |0\.\d*[1-9]\d* |0?\.0+ |0)$  //匹配浮點數
^[1-9]\d*\.\d* |0\.\d*[1-9]\d* |0?\.0+ |0$   //匹配非負浮點數(正浮點數 + 0)
^(-([1-9]\d*\.\d* |0\.\d*[1-9]\d*)) |0?\.0+ |0$  //匹配非正浮點數(負浮點數 + 0)
評註:處理大量數據時有用,具體應用時注意修正
匹配特定字符串:
^[A-Za-z]+$  //匹配由26個英文字母組成的字符串
^[A-Z]+$  //匹配由26個英文字母的大寫組成的字符串
^[a-z]+$  //匹配由26個英文字母的小寫組成的字符串
^[A-Za-z0-9]+$  //匹配由數字和26個英文字母組成的字符串
^\w+$  //匹配由數字、26個英文字母或者下劃線組成的字符串
"^[\\w-]+(+)*@[\\w-]+(\\.[\\w-]+)+___FCKpd___0quot]\\.[\\w-]+)*@[\\w-]+(\\.[\\w-]+)+___FCKpd___0quot;    //email地址
"^[a-zA-z]+://(\\w+(-\\w+)*)(\\.(\\w+(-\\w+)*))*(\\?\\S*)?___FCKpd___0quot;  //urlview plaincopy to clipboardprint?
正則幾個基本概念: 
正則幾個基本概念:view plaincopy to clipboardprint?
1.貪婪:+,*,?,{m,n}等默認是貪婪匹配,即儘量多匹配,也叫最大匹配 
若是後面加上?,就轉化爲非貪婪匹配,須要高版本支持 
1.貪婪:+,*,?,{m,n}等默認是貪婪匹配,即儘量多匹配,也叫最大匹配
若是後面加上?,就轉化爲非貪婪匹配,須要高版本支持view plaincopy to clipboardprint?
2.獲取:默認用(x |y)是獲取匹配,不少時候只是測試,不必定要求獲得所匹配的數據,尤爲在嵌套匹配或大數據中就要用非獲取匹配(?:x |y),這樣提升了效率,優化了程序。 
2.獲取:默認用(x |y)是獲取匹配,不少時候只是測試,不必定要求獲得所匹配的數據,尤爲在嵌套匹配或大數據中就要用非獲取匹配(?:x |y),這樣提升了效率,優化了程序。view plaincopy to clipboardprint?
3.消耗:默認是消耗匹配,通常在預查中是非消耗匹配。 
舉個例子,2003-2-8要變爲2003-02-08 
若是用/-(\d)-/第二次匹配將從8開始,從而只替換第一個2,錯誤 
若是用/-(\d)(?=-)/則第二次匹配從第二個-開始,即不消耗字符- 
3.消耗:默認是消耗匹配,通常在預查中是非消耗匹配。
舉個例子,2003-2-8要變爲2003-02-08
若是用/-(\d)-/第二次匹配將從8開始,從而只替換第一個2,錯誤
若是用/-(\d)(?=-)/則第二次匹配從第二個-開始,即不消耗字符-view plaincopy to clipboardprint?
4.預查:js中分爲正向預查和負向預查 
如上面的(?=pattern)是正向預查,在任何匹配 pattern 的字符串開始處匹配查找字符串。還有(?!pattern)是負向預查,在任何不匹配 pattern 的字符串開始處匹配查找字符串。負向預查有時會用在對[^]的擴充,[^]只是一些字符,而?!可使整個字符串。 
4.預查:js中分爲正向預查和負向預查
如上面的(?=pattern)是正向預查,在任何匹配 pattern 的字符串開始處匹配查找字符串。還有(?!pattern)是負向預查,在任何不匹配 pattern 的字符串開始處匹配查找字符串。負向預查有時會用在對[^]的擴充,[^]只是一些字符,而?!可使整個字符串。view plaincopy to clipboardprint?
5.回調:通常用在替換上,即根據不用的匹配內容返回不用的替換值,從而簡化了程序,須要高版本支持 
5.回調:通常用在替換上,即根據不用的匹配內容返回不用的替換值,從而簡化了程序,須要高版本支持view plaincopy to clipboardprint?
6.引用:\num 對所獲取的第num個匹配的引用。 
例如,'(.)\1\1' 匹配AAA型。'(.)(.)\2\1' 匹配ABBA型。 
6.引用:\num 對所獲取的第num個匹配的引用。
例如,'(.)\1\1' 匹配AAA型。'(.)(.)\2\1' 匹配ABBA型。view plaincopy to clipboardprint?
正則表達式保留字 
^ (carat)   
. (period)   
[ (left bracket}   
$ (dollar sign)   
( (left parenthesis)   
) (right parenthesis)   
| (pipe)   
* (asterisk)   
+ (plus symbol)   
? (question mark)   
{ (left curly bracket, or left brace)   
\ backslash 
正則表達式保留字
^ (carat)
. (period)
[ (left bracket}
$ (dollar sign)
( (left parenthesis)
) (right parenthesis)
| (pipe)
* (asterisk)
+ (plus symbol)
? (question mark)
{ (left curly bracket, or left brace)
\ backslash view plaincopy to clipboardprint?
構造 匹配於 
構造 匹配於 view plaincopy to clipboardprint?
字符   
x 字符 x   
\\ 反斜線字符   
\0n 八進制值的字符0n (0 <= n <= 7)   
\0nn 八進制值的字符 0nn (0 <= n <= 7)   
\0mnn 八進制值的字符0mnn 0mnn (0 <= m <= 3, 0 <= n <= 7)   
\xhh 十六進制值的字符0xhh   
\uhhhh 十六進制值的字符0xhhhh   
\t 製表符('\u0009')   
\n 換行符 ('\u000A')   
\r 回車符 ('\u000D')   
\f 換頁符 ('\u000C')   
\a 響鈴符 ('\u0007')   
\e 轉義符 ('\u001B')   
\cx T對應於x的控制字符 x 
字符
x 字符 x
\\ 反斜線字符
\0n 八進制值的字符0n (0 <= n <= 7)
\0nn 八進制值的字符 0nn (0 <= n <= 7)
\0mnn 八進制值的字符0mnn 0mnn (0 <= m <= 3, 0 <= n <= 7)
\xhh 十六進制值的字符0xhh
\uhhhh 十六進制值的字符0xhhhh
\t 製表符('\u0009')
\n 換行符 ('\u000A')
\r 回車符 ('\u000D')
\f 換頁符 ('\u000C')
\a 響鈴符 ('\u0007')
\e 轉義符 ('\u001B')
\cx T對應於x的控制字符 x view plaincopy to clipboardprint?
字符類   
[abc] a, b, or c (簡單類)   
[^abc] 除了a、b或c以外的任意 字符(求反)   
[a-zA-Z] a到z或A到Z ,包含(範圍)   
[a-z-[bc]] a到z,除了b和c : [ad-z](減去)   
[a-z-正則表達式

] a到z,除了m到 p: [a-lq-z]   
[a-z-[^def]] d, e, 或 f 
字符類
[abc] a, b, or c (簡單類)
[^abc] 除了a、b或c以外的任意 字符(求反)
[a-zA-Z] a到z或A到Z ,包含(範圍)
[a-z-[bc]] a到z,除了b和c : [ad-z](減去)
[a-z-
] a到z,除了m到 p: [a-lq-z]
[a-z-[^def]] d, e, 或 f view plaincopy to clipboardprint?
預約義的字符類   
. 任意字符(也許能與行終止符匹配,也許不能)   
\d 數字: [0-9]   
\D 非數字: [^0-9]   
\s 空格符: [ \t\n\x0B\f\r]   
\S 非空格符: [^\s]   
\w 單詞字符: [a-zA-Z_0-9]   
\W 非單詞字符: [^\w]curl

相關文章
相關標籤/搜索
本站公眾號
   歡迎關注本站公眾號,獲取更多信息