JAVA正則表達式4種常用功能

正則表達式在字符串處理上有着強大的功能,sun在jdk1.4加入了對它的支持
 
  下面簡單的說下它的4種常用功能:
  
  查詢:
  
以下是代碼片段:
 String str="abc efg ABC";
 
String regEx="a|f"; //表示a或f
 
 Pattern p=Pattern.compile(regEx);
 
 Matcher m=p.matcher(str);
 
 boolean rs=m.find();
  
  如果str中有regEx,那麼rs爲true,否則爲flase。如果想在查找時忽略大小寫,則可以寫成Pattern p=Pattern.compile(regEx,Pattern.CASE_INSENSITIVE);
  
  提取:
以下是代碼片段:
 String regEx=".+/(.+)$";
 
String str="c:/dir1/dir2/name.txt";
 
 Pattern p=Pattern.compile(regEx);
 
 Matcher m=p.matcher(str);
 
 boolean rs=m.find();
 
 for(int i=1;i<=m.groupCount();i++){
 
 System.out.println(m.group(i));
 
 }

  
  以上的執行結果爲name.txt,提取的字符串儲存在m.group(i)中,其中i最大值爲m.groupCount();
  
  分割:
  
以下是代碼片段:
String regEx="::";
 
 Pattern p=Pattern.compile(regEx);
 
 String[] r=p.split("xd::abc::cde");
 
 執行後,r就是{"xd","abc","cde"},其實分割時還有跟簡單的方法:
 
 String str="xd::abc::cde";
 
 String[] r=str.split("::");

  
  替換(刪除):
  
以下是代碼片段:
 String regEx="a+"; //表示一個或多個a

 Pattern p=Pattern.compile(regEx);
 
 Matcher m=p.matcher("aaabbced a ccdeaa");
 
 String s=m.replaceAll("A");
  
  結果爲"Abbced A ccdeA"
  
  如果寫成空串,既可達到刪除的功能,比如:
  
String s=m.replaceAll("");
  
  結果爲"bbced ccde"
  
  附:
  
 /D 等於 [^0-9] 非數字
 /s 等於 [ /t/n/x0B/f ] 空白字元
 /S 等於 [^ /t/n/x0B/f ] 非空白字元
 /w 等於 [a-zA-Z_0-9] 數字或是英文字
 /W 等於 [^a-zA-Z_0-9] 非數字與英文字
  
  ^ 表示每行的開頭
  $ 表示每行的結尾

"^/d+$"  //非負整數(正整數 + 0)
"^/[0-9/]*/[1-9/]/[0-9/]*$"  //正整數
"^((-/d+)/|(0+))$"  //非正整數(負整數 + 0)
"^-/[0-9/]*/[1-9/]/[0-9/]*$"  //負整數
"^-?/d+$"    //整數
"^/d+(/./d+)?$"  //非負浮點數(正浮點數 + 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+)?)/|(0+(/.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+)?$"  //浮點數
"^/[A-Za-z/]+$"  //由26個英文字母組成的字符串
"^/[A-Z/]+$"  //由26個英文字母的大寫組成的字符串
"^/[a-z/]+$"  //由26個英文字母的小寫組成的字符串
"^/[A-Za-z0-9/]+$"  //由數字和26個英文字母組成的字符串
"^/w+$"  //由數字、26個英文字母或者下劃線組成的字符串
"^/[/w-/]+(/./[/w-/]+)*@/[/w-/]+(/./[/w-/]+)+$"    //email地址
"^/[a-zA-z/]+://(/w+(-/w+)*)(/.(/w+(-/w+)*))*(/?/S*)?$"  //url
/^(d{2}/|d{4})-((0(/[1-9/]{1}))/|(1/[1/|2/]))-((/[0-2/](/[1-9/]{1}))/|(3/[0/|1/]))$/&nbsp;&nbsp; //&nbsp; 年-月-日
/^((0(/[1-9/]{1}))/|(1/[1/|2/]))/((/[0-2/](/[1-9/]{1}))/|(3/[0/|1/]))/(d{2}/|d{4})$/&nbsp;&nbsp; // 月/日/年
"^(/[w-./]+)@((/[/[0-9/]{1,3}./[0-9/]{1,3}./[0-9/]{1,3}.)/|((/[w-/]+.)+))(/[a-zA-Z/]{2,4}/|/[0-9/]{1,3})(/]?)$"&nbsp;&nbsp; //Emil
"(d+-)?(d{4}-?d{7}/|d{3}-?d{8}/|^d{7,8})(-d+)?"  //電話號碼
"^(d{1,2}/|1dd/|2/[0-4/]d/|25/[0-5/]).(d{1,2}/|1dd/|2/[0-4/]d/|25/[0-5/]).(d{1,2}/|1dd/|2/[0-4/]d/|25/[0-5/]).(d{1,2}/|1dd/|2/[0-4/]d/|25/[0-5/])$"&nbsp;&nbsp; //IP地址

匹配中文字符的正則表達式: /[/u4e00-/u9fa5/]
匹配雙字節字符(包括漢字在內):/[^/x00-/xff/]
匹配空行的正則表達式:/n/[/s/| /]*/r
匹配HTML標記的正則表達式:/<(.*)>.*<///1>/|<(.*) //>/
匹配首尾空格的正則表達式:(^/s*)/|(/s*$)
匹配Email地址的正則表達式:/w+(/[-+./]/w+)*@/w+(/[-./]/w+)*/./w+(/[-./]/w+)/*
匹配網址URL的正則表達式:^/[a-zA-z/]+://(//w+(-//w+)*)(//.(//w+(-//w+)*))*(//?//S*)?$
匹配帳號是否合法(字母開頭,允許5-16字節,允許字母數字下劃線):^/[a-zA-Z/]/[a-zA-Z0-9_/]{4,15}$
匹配國內電話號碼:(/d{3}-/|/d{4}-)?(/d{8}/|/d{7})?
匹配騰訊QQ號:^/[1-9/]*/[1-9/]/[0-9/]*$

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

匹配中文字符的正則表達式: [/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位

匹配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個英文字母或者下劃線組成的字符串

 

from:http://blog.csdn.net/lu7kang/archive/2008/12/11/3496696.aspx

發佈了16 篇原創文章 · 獲贊 44 · 訪問量 19萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章