小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

Java中正則表達式的使用

 橘子悅讀 2013-08-27

      在Java中,我們?yōu)榱瞬檎夷硞€給定字符串中是否有需要查找的某個字符或者子字串、或者對字符串進行分割、或者對字符串一些字符進行替換/刪除,一般會通過if-else、for 的配合使用來實現這些功能 。如下所示:

 

Java代碼  收藏代碼
  1. public class Test{  
  2.   public static void main(String args[]) {  
  3.          String str="@Shang Hai Hong Qiao Fei Ji Chang";  
  4.          boolean rs = false;  
  5.          for(int i=0;i<str.length();i++){  
  6.                 char z=str.charAt(i);    
  7.                 if('a' == z || 'F' == z) {  
  8.                        rs  = true;  
  9.                        break;  
  10.                 }else{  
  11.                        rs= false;  
  12.                 }  
  13.          }     
  14.          System.out.println(rs);  
  15.        }  
  16. }  

      這種方法使用簡單直觀,但是 難以解決復雜的工作,而且代碼量也會增加很多,不利于維護。

 

      這時,我們可以使用正則表達式來實現這些功能,而且代碼簡單易維護。下面就來介紹了Java中對字符串的正則表達式的幾個常用的功能,具體情況如下所示(其中用到了java.util.regex包):

 

1.Java中在某個字符串中查詢某個字符或者某個子字串

Java代碼  收藏代碼
  1. String s = "@Shang Hai Hong Qiao Fei Ji Chang";     
  2. String regEx = "a|F"; //表示a或F  
  3. Pattern pat = Pattern.compile(regEx);  
  4. Matcher mat = pat.matcher(s);  
  5. boolean rs = mat.find();   

    如果s中有regEx,那么rs為true,否則為flase。

    如果想在查找時忽略大小寫,則可以寫成Pattern pat=Pattern.compile(regEx,Pattern.CASE_INSENSITIVE);

 

2.在某個文件中獲取一段字符串

Java代碼  收藏代碼
  1. String regEx = ".+\(.+)$";  
  2. String s = "c:\test.txt";  
  3. Pattern pat = Pattern.compile(regEx);  
  4. Matcher mat = pat.matcher(s);  
  5. boolean rs = mat.find();  
  6. for(int i=1;i<=mat.groupCount();i++){  
  7.   System.out.println(mat.group(i));  
  8. }   

  以上的執(zhí)行結果為test.txt,提取的字符串儲存在mat.group(i)中,其中i最大值為mat.groupCount();

 

3.對字符串的分割

Java代碼  收藏代碼
  1. String regEx=":";  
  2. Pattern pat = Pattern.compile(regEx);  
  3. String[] rs = pat.split("aa:bb:cc");   

  執(zhí)行后,r就是{"aa","bb","cc"}

    如果用正則表達式分割就如上所示,一般我們都會使用下面更簡單的方法:

Java代碼  收藏代碼
  1. String s = "aa:bb:cc";  
  2. String[] rs=s.split(":");   

 

4.字符串的替換/刪除

Java代碼  收藏代碼
  1. String regEx="@+"; //表示一個或多個@  
  2. Pattern pat=Pattern.compile(regEx);  
  3. Matcher mat=pat.matcher("@@aa@b cc@@");  
  4. String s=mat.replaceAll("#");   

 結果為"##aa#b cc##"
  
 如果要把字符串中的@都給刪除,只用要空字符串替換就可以了:

Java代碼  收藏代碼
  1. String s=mat.replaceAll("");  

  結果為"aab cc"

 

 

注:對Pattern類的說明:
      1.public final class java.util.regex.Pattern是正則表達式編譯后的表達法。

      下面的語句將創(chuàng)建一個Pattern對象并賦值給句柄pat:Pattern pat = Pattern.compile(regEx);
      有趣的是,Pattern類是final類,而且它的構造器是private。也許有人告訴你一些設計模式的東西,或者你自己查有關資料。這里的結論是:Pattern類不能被繼承,我們不能通過new創(chuàng)建Pattern類的對象。
       因此在Pattern類中,提供了2個重載的靜態(tài)方法,其返回值是Pattern對象(的引用)。如:

Java代碼  收藏代碼
  1. public static Pattern compile(String regex) {  
  2.         return new Pattern(regex, 0);  
  3. }  

       當然,我們可以聲明Pattern類的句柄,如Pattern pat = null;

 

    2.pat.matcher(str)表示以用Pattern去生成一個字符串str的匹配器,它的返回值是一個Matcher類的引用。
       我們可以簡單的使用如下方法:boolean rs = Pattern.compile(regEx).matcher(str).find();

 

 

常用的正則表達式:

匹配特定數字:
^[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]
匹配雙字節(jié)字符(包括漢字在內):[^x00-xff]
匹配空行的正則表達式:n[s| ]*r
匹配HTML標記的正則表達式:/< (.*)>.*|< (.*) />/
匹配首尾空格的正則表達式:(^s*)|(s*$)
匹配Email地址的正則表達式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*
匹配網址URL的正則表達式:http://([w-]+.)+[w-]+(/[w- ./?%&=]*)?

 

    本站是提供個人知識管理的網絡存儲空間,所有內容均由用戶發(fā)布,不代表本站觀點。請注意甄別內容中的聯系方式、誘導購買等信息,謹防詐騙。如發(fā)現有害或侵權內容,請點擊一鍵舉報。
    轉藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多