日常收集整理正規表示式驗證大全

受到鼓舞人發表於2022-03-21

常用正規表示式大全!(例如:匹配中文、匹配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個英文字母或者下劃線組成的字串  

 在使用RegularExpressionValidator驗證控制元件時的驗證功能及其驗證表示式介紹如下:  

 只能輸入數字:“^[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- ./?%&=]*)?

 (5)應用:利用正規表示式限制網頁表單裡的文字框輸入內容  

 用正規表示式限制只能輸入中文:

複製程式碼程式碼如下:

"  


用正規表示式限制只能輸入全形字元:

複製程式碼程式碼如下:

"onbeforepaste="clipboardData.setData(''text'',clipboardData.getData(''text'').replace(/[^uFF00-uFFFF]/g,''))"

  

用正規表示式限制只能輸入數字:

複製程式碼程式碼如下:

"  


用正規表示式限制只能輸入數字和英文:

複製程式碼程式碼如下:

"onbeforepaste="clipboardData.setData(''text'',clipboardData.getData(''text'').replace(/[^d]/g,''


用途:判斷是否是日期 輸入:date:日期;fmt:日期格式 返回:如果通過驗證返回true,否則返回false

 */ function isDate( date, fmt ) { 
if (fmt==null) fmt="yyyyMMdd"; 
var yIndex = fmt.indexOf("yyyy"); 
if(yIndex==-1) 
return false; 
var year = date.substring(yIndex,yIndex+4); 
var mIndex = fmt.indexOf("MM"); 
if(mIndex==-1)
return false; 
var month = date.substring(mIndex,mIndex+2); 
var dIndex = fmt.indexOf("dd"); 
if(dIndex==-1)
return false; 
var day = date.substring(dIndex,dIndex+2); 
if(!isNumber(year)||year>"2100" || year< "1900") 
return false; 
if(!isNumber(month)||month>"12" || month< "01") 
return false;
if(day>getMaxDay(year,month) || day< "01") 
return false; 
return true; 
} 
function getMaxDay(year,month) { 
if(month==4||month==6||month==9||month==11) return "30"; 
if(month==2) i
f(year%4==0&&year%100!=0 || year%400==0) 
return "29"; 
else return "28"; 
return "31"; 
}

正規表示式驗證大全小編就給大家介紹到這裡,希望對大家有所幫助!

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

相關文章