隨筆-26  評論-111  文章-19  trackbacks-0
          JAVA正則表達(dá)式4種常用功能 
             
            正則表達(dá)式在字符串處理上有著強(qiáng)大的功能,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)); 
           
           } 

            
            以上的執(zhí)行結(jié)果為name.txt,提取的字符串儲存在m.group(i)中,其中i最大值為m.groupCount();
            
            分割:
            
          以下是代碼片段:
          String regEx="::"; 
           
           Pattern p=Pattern.compile(regEx); 
           
           String[] r=p.split("xd::abc::cde"); 
           
           執(zhí)行后,r就是{"xd","abc","cde"},其實(shí)分割時還有跟簡單的方法: 
           
           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"); 
            
            結(jié)果為"Abbced A ccdeA"
            
            如果寫成空串,既可達(dá)到刪除的功能,比如:
            
          String s=m.replaceAll("");
            
            結(jié)果為"bbced ccde"
            
            附:
            
           \D 等於 [^0-9] 非數(shù)字 
           \s 等於 [ \t\n\x0B\f ] 空白字元 
           \S 等於 [^ \t\n\x0B\f ] 非空白字元 
           \w 等於 [a-zA-Z_0-9] 數(shù)字或是英文字 
            \W 等於 [^a-zA-Z_0-9] 非數(shù)字與英文字 
            
            ^ 表示每行的開頭
            $ 表示每行的結(jié)尾
          posted on 2005-10-09 14:45 snoics 閱讀(285) 評論(0)  編輯  收藏 所屬分類: 它山之石
          主站蜘蛛池模板: 文昌市| 烟台市| 玉山县| 西峡县| 竹山县| 花莲市| 徐州市| 临沧市| 家居| 泰安市| 错那县| 且末县| 翼城县| 阿克陶县| 闵行区| 钟祥市| 嘉善县| 石楼县| 湟源县| 弥渡县| 泸州市| 武宁县| 卢龙县| 榆中县| 老河口市| 万安县| 孙吴县| 盐边县| 阿巴嘎旗| 县级市| 寻乌县| 古蔺县| 余姚市| 岚皋县| 泰来县| 三明市| 福建省| 江津市| 博白县| 茂名市| 名山县|