JAVA編程——常用正則表達式

正則規則
(1):特殊字符
      \\:反斜線
      \r:回車
      \n:換行

(2):字符類
[abc]:a,b或者c的任意一個。
[^abc]:除了a,b,c以外的字符。
[a-zA-Z]:包括了26個英文字母。
[0-9]:包括了0-9這個10個數字字符。

(3):預定義字符類
.         任意字符
\d         數字[0-9]
\D         非數字[^0-9]
\w         單詞字符:[a-zA-Z_0-9]
\W         非單詞字符:[^\w]

(4):邊界匹配器
^         行的開頭
$         行的結尾
\b         單詞邊界

(5):Greedy 數量詞
x?         0次或1次
x*         0次或多次
x+         1次或多次
x{n} 恰好n次
x{n,} 至少n次
x{m,n} 至少m次,但不能超過n次

正則表達式用於字符串處理、表單驗證等場合,實用高效。現將一些常用的表達式收集於此,以備不時之需。

匹配中文字符的正則表達式: [\u4e00-\u9fa5]
評註:匹配中文還真是個頭疼的事,有了這個表達式就好辦了

匹配雙字節字符(包括漢字在內):[^\x00-\xff]
評註:可以用來計算字符串的長度(一個雙字節字符長度計2,ASCII字符計1)

匹配空白行的正則表達式:\n\s*\r
評註:可以用來刪除空白行

匹配HTML標記的正則表達式:<(\S*?)[^>]*>.*?</\1>|<.*? />
評註:網上流傳的版本太糟糕,上面這個也僅僅能匹配部分,對於複雜的嵌套標記依舊無能爲力

匹配首尾空白字符的正則表達式:^\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位

匹配特定數字:
^[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個英文字母或者下劃線組成的字符串
評註:最基本也是最常用的一些表達式
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章