小石頭
          Excellence in any department can be attained only by the labor of a lifetime; it is not to be purchased at a lesser price.
          posts - 91,comments - 22,trackbacks - 0
          正則表達式在字符串處理上有著強大的功能,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] 非數字與英文字
            
            ^ 表示每行的開頭
            $ 表示每行的結尾
          posted on 2007-02-12 20:14 小石頭 閱讀(209) 評論(0)  編輯  收藏 所屬分類: 每天學一點
          主站蜘蛛池模板: 安泽县| 涟水县| 新竹县| 松阳县| 五大连池市| 汾西县| 罗定市| 阿拉善左旗| 盘山县| 永川市| 阜康市| 准格尔旗| 广东省| 两当县| 乌鲁木齐县| 麻江县| 宁南县| 古丈县| 嘉禾县| 淮南市| 沁源县| 彩票| 琼结县| 武宁县| 辽宁省| 大竹县| 榆社县| 汉源县| 北票市| 封开县| 海林市| 秦安县| 新郑市| 澳门| 岳西县| 洛浦县| 亳州市| 镇远县| 黄龙县| 鲜城| 特克斯县|