正規表示式 常用的正則

2021-05-23 08:03:18 字數 3518 閱讀 4156

匹配中文字元的正規表示式: [/u4e00-/u9fa5]

匹配雙位元組字元(包括漢字在內):[^/x00-/xff]

匹配空行的正規表示式:/n[/s| ]*/r

匹配html標記的正規表示式:/<(.*)>.*|<(.*) //>/

匹配首尾空格的正規表示式:(^/s*)|(/s*$)

匹配**url的正規表示式:http://([/w-]+/.)+[/w-]+(/[/w- ./?%&=]*)?

匹配**url的正規表示式:(((ht|f)tp(s?):)|(www/.[^ /[/]/(/)/n/r/t]+)|(([012]?[0-9]/.)[012]?[0-9])//)([^ /[/]/(/),;"'<>/n/r/t]+)([^/. /[/]/(/),;"'<>/n/r/t])|(([012]?[0-9]/.)[012]?[0-9])

匹配非負整數(正整數 + 0): ^/d+$  

匹配正整數: ^[0-9]*[1-9][0-9]*$  

匹配非正整數(負整數 + 0): ^((-/d+)|(0+))$  

匹配負整數: ^-[0-9]*[1-9][0-9]*$  

匹配整數: ^-?/d+$    

匹配非負浮點數(正浮點數 + 0): ^/d+(/./d+)?$  

匹配正浮點數: ^(([0-9]+/.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*/.[0-9]+)|([0-9]*[1-9][0-9]*))$  

匹配非正浮點數(負浮點數 + 0): ^((-/d+(/./d+)?)|(0+(/.0+)?))$  

匹配負浮點數 : ^(-(([0-9]+/.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*/.[0-9]+)|([0-9]*[1-9][0-9]*)))$  

匹配浮點數: ^(-?/d+)(/./d+)?$  

匹配由26個英文本母組成的字串: ^[a-za-z]+$  

匹配由26個英文本母的大寫組成的字串 : ^[a-z]+$  

匹配由26個英文本母的小寫組成的字串: ^[a-z]+$  

匹配由數字和26個英文本母組成的字串: ^[a-za-z0-9]+$  

匹配由數字、26個英文本母或者下劃線組成的字串: ^/w+$  

匹配url : ^[a-za-z]+://匹配(/w+(-/w+)*)(/.(/w+(-/w+)*))*(/?/s*)?$  

匹配中文字元的正規表示式

: [/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_]$

評注:表單驗證時很實用

匹配國內**號碼:/d-/d|/d-/d

評注:匹配形式如 0511-4405222 或 021-87888822

匹配身份證:/d|/d

評注:中國的身份證為15位或18位

匹配特定數字:

^[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個英文本母或者下劃線組成的字串

評注:最基本也是最常用的一些表示式

上述日期還需要加上時間 在後面加段  「空格 (20|21|22|23|[0-1]?/d):[0-5]?/d:[0-5]?/d 」即可。

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

用正規表示式限制只能輸入中文:οnkeyup="value=value.replace(/[^/u4e00-/u9fa5]/g,'')" onbeforepaste="clipboarddata.setdata('text',clipboarddata.getdata('text').replace(/[^/u4e00-/u9fa5]/g,''))"

用正規表示式限制只能輸入全形字符: ')" onbeforepaste="clipboarddata.setdata('text',clipboarddata.getdata('text').replace(/[^/uff00-/uffff]/g,''))"

用正規表示式限制只能輸入數字:οnkeyup="value=value.replace(/[^/d]/g,'') "onbeforepaste="clipboarddata.setdata('text',clipboarddata.getdata('text').replace(/[^/d]/g,''))"

用正規表示式限制只能輸入數字和英文:οnkeyup="value=value.replace(/[/w]/g,'') "onbeforepaste="clipboarddata.setdata('text',clipboarddata.getdata('text').replace(/[^/d]/g,''))"

正規表示式 常用正規表示式

一 校驗數字的表示式 1 數字 0 9 2 n位的數字 d 3 至少n位的數字 d 4 m n位的數字 d 5 零和非零開頭的數字 0 1 9 0 9 6 非零開頭的最多帶兩位小數的數字 1 9 0 9 0 9 7 帶1 2位小數的正數或負數 d d 8 正數 負數 和小數 d d 9 有兩位小數的...

正規表示式 常用正規表示式

網域名稱 a za z0 9 a za z0 9 a za z0 9 a za z0 9 interneturl a za z s 或 http w w w 手機號碼 13 0 9 14 5 7 15 0 1 2 3 4 5 6 7 8 9 18 0 1 2 3 5 6 7 8 9 d 或者 1 3...

正規表示式 常用的正則

yes i 匹配 yes的 不區分大小寫 s 匹配 任何字元 x 新增空格 u 要求緊接著的都是大寫 l 要求後面的全部是小寫 可選的負號 d 小數點前乙個或多個十進位制數字 可選的小數點 d 小數點後一些可選的十進位制數字 x 模式結束 bfred b 匹配 fred 只能 bhunt 將匹配 h...