正則表達式在字符串處理上有着強大的功能,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/]))$/ // 年-月-日
/^((0(/[1-9/]{1}))/|(1/[1/|2/]))/((/[0-2/](/[1-9/]{1}))/|(3/[0/|1/]))/(d{2}/|d{4})$/ // 月/日/年
"^(/[w-./]+)@((/[/[0-9/]{1,3}./[0-9/]{1,3}./[0-9/]{1,3}.)/|((/[w-/]+.)+))(/[a-zA-Z/]{2,4}/|/[0-9/]{1,3})(/]?)$" //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/])$" //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