天天看點

常用正規表達式(一)

正規表達式含義:

          d 代表 [0-9]

          l 代表 [a-z]

          u 代表 [A-Z]

          a 代表 [A-Za-z]

          w 代表 [A-Za-z0-9_]

比對特定格式::     

       比對中文字元的正規表達式: [u4e00-u9fa5]  

       比對雙位元組字元(包括漢字在内):[^x00-xff] 

  比對空白行的正規表達式:ns*r 

         比對首尾空白字元的正規表達式:首  ^\s*

                                                                               尾  \s*$

  比對HTML标記的正規表達式:<(S*?)[^>]*>.*?|<.*? /> 

  比對首尾空白字元的正規表達式:^s*|s*$ 

  比對Email位址的正規表達式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)* 

  比對網址URL的正規表達式:[a-zA-z]+://[^s]* 或者\(\l\|\u\)\+://[^\s]* 或者 \(\l\|\u\)\+://(\w\+(-\w\+)*)(\.(\w\+(-\w\+)*))*(\?\S*)?

  比對帳号是否合法(字母開頭,允許5-16位元組,允許字母數字下劃線):^[a-zA-Z][a-zA-Z0-9_]{4,15}$ 

  比對國内電話号碼:d{3}-d{8}|d{4}-d{7} 

  比對騰訊QQ号:[1-9][0-9]{4,} 

  比對中國郵政編碼:[1-9]d{5}(?!d) 

  比對身份證:d{15}|d{18} |d{17}[xX]  

       比對ip位址:d+.d+.d+.d+ 

         比對Email位址的正規表達式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)* 或者 [\w-]\+(\.[\w-]\+)*@[\w-]\+(\.[\w-]\+)\+

比對特定數字: 

  ^[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*$) 

(1)應用:計算字元串的長度(一個雙位元組字元長度計2,ASCII字元計1) 

  String.prototype.len=function(){return this.replace([^x00-xff]/g,"aa").length;} 

  String.prototype.trim = function() 

  { 

  return this.replace(/(^s*)|(s*$)/g, ""); 

  } 

  (3)應用:利用正規表達式分解和轉換IP位址 

  function IP2V(ip) //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!") 

  s=s.replace(/(.*/){0,}([^.]+).*/ig,"$2") ;//Page1.htm 

  (5)應用:利用正規表達式限制網頁表單裡的文本框輸入内容 

  用正規表達式限制隻能輸入中文: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,''

      本文轉自MQ_douer 51CTO部落格,原文連結:http://blog.51cto.com/douer/1936580,如需轉載請自行聯系原作者

繼續閱讀