值得收藏的正規表示式大全

給我任何的發表於2022-03-19

正規表示式,又稱正規表示法、常規表示法。(英語:Regular Expression,在程式碼中常簡寫為regex、regexp或RE),電腦科學的一個概念。正規表示式使用單個字串來描述、匹配一系列符合某個句法規則。在很多文字編輯器裡,正規表示式通常被用來檢索、替換那些符合某個模式的文字。

一、歸類

1. “^” 同類

“^” 匹配輸入字串的開始位置。
“$” 匹配輸入字串的結束位置。
“\b” 匹配一個單詞邊界,也就是指單詞和空格間的位置。(例如:”er\b”可以匹配”never”中的”er”,但是不能匹配”verb”中的”er”)
“\B” 和”\b”相反,匹配非單詞邊界(例如:”er\b”可以匹配”verb”中的”er”,但是不能匹配”never”中的”er”)

2.”*” 同類

星號(*): 星號代表匹配它前面一個字元任意遍(0或任意次)。
加號(+): 表示匹配前面字元一次或多次(至少一次)。
問號(?): 問號也是一個數量詞,它代表匹配前一個字元0次或1次。
中括號[]: 中括號用來表示一個字符集合,如果這個集合有很多元素,如26個字母,數字等,一個個地寫在中括號裡,未免太麻煩了,所以一般我們用連字元來表示一個範圍(例如:[a-z]表示小寫字母的集合;[a-zA-Z]表示大小寫字母的集合)。脫字元”^”表示匹配任何不在該集合中的字元。(例如:[^a-z])。
大括號{}: 大括號的作用是指重複前面一個字元多少遍(例如:{N}:重複n遍;{n,m}:重複n~m遍;{n,}:至少重複n遍;{,m}:最多重複m遍)

3.”\s” 同類

“\w” (小寫w)表示字母或數字,等價於[a-zA-Z0-9]
“\W” (大寫W)表示非字母且非數字,與\w相反,等價於[^a-zA-Z0-9]
“\s” (小寫s)表示匹配一個空字元,包括空格,換行,回車,tab,等價於[ \n\r\t\f]
“\S” (大寫S)匹配非空格字元,與\s相反,等價於[^ \n\r\t\f]
“\d” (小寫d)表示十進位制數字,等價於[0-9]
“\D” (大寫D)匹配一個非數字字元,等價於[^0-9]

二、宣告一個checkNum函式

function checkNum(input){
 /*表示必須是1或者多個數字*/
 var regex = /^[A-Z]{6,12}$/;
 if (input.match(regex)) {
 return true;
 } else {
 return false;
 }
}

三、宣告一個checkEmail函式

function checkEmail(input){
 var regex = /^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/;
 if (input.match(regex)) {
  return true;
 } else {
  return false;
 }
 }
}

四、封裝一個trim()

var my = function() {};
my.prototype = {
 ltrim: function(str) {
 return str.replace(/(^\s*)/g,'');
 },
 rtrim: function(str){
 return str.replace(/(\s*$)/g,'');
 },
 trim: function(str){
 return str.replace(/(^\s*)|(\s*$)/g,'');
 } 
}
 /*^ 以xx開頭*/
 /*\s 表示空格*/
 /**表示匹配零個或者多個*/
 /*g 表示匹配全部*/
 /*(^\s*)表示匹配以空格開頭一個或者多個字元*/
 /*str.replace(/(^\s*)/g,'') 表示用''替換所有的空格*/

附:常用正規表示式大全!(例如:匹配中文、匹配html)

匹配中文字元的正規表示式: [u4e00-u9fa5]
評註:匹配中文還真是個頭疼的事,有了這個表示式就好辦了
匹配雙位元組字元(包括漢字在內):[^x00-xff]
評註:可以用來計算字串的長度(一個雙位元組字元長度計2,ASCII字元計1)
匹配空白行的正規表示式:ns*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個英文字母或者下劃線組成的字串

只能輸入數字:“^[0-9]*$”
只能輸入n位的數字:“^d{n}$”
只能輸入至少n位數字:“^d{n,}$”
只能輸入m-n位的數字:“^d{m,n}$”
只能輸入零和非零開頭的數字:“^(0|[1-9][0-9]*)$”
只能輸入有兩位小數的正實數:“^[0-9]+(.[0-9]{2})?$”
只能輸入有1-3位小數的正實數:“^[0-9]+(.[0-9]{1,3})?$”
只能輸入非零的正整數:“^+?[1-9][0-9]*$”
只能輸入非零的負整數:“^-[1-9][0-9]*$”
只能輸入長度為3的字元:“^.{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}$”
正確格式為:“XXXX-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”。
匹配中文字元的正規表示式: [u4e00-u9fa5]
匹配雙位元組字元(包括漢字在內):[^x00-xff]
匹配空行的正規表示式:n[s| ]*r
匹配HTML標記的正規表示式:/<(.*)>.*|<(.*) />/
匹配首尾空格的正規表示式:(^s*)|(s*$)
匹配Email地址的正規表示式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*
匹配網址URL的正規表示式:http://([w-]+.)+[w-]+(/[w- ./?%&=]*)?*/

以上就是本文的全部內容,希望對大家的學習有所幫助。


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/70015106/viewspace-2874048/,如需轉載,請註明出處,否則將追究法律責任。

相關文章