u-s-soldiers

          BlogJava 首頁 新隨筆 聯(lián)系 聚合 管理
            13 Posts :: 0 Stories :: 1 Comments :: 0 Trackbacks

          2008年5月3日 #

          public class StringUtil {

            
           public static void replaceBlank()
           {
            Pattern p = Pattern.compile(\\s*|\t|\r|\n);
            String str="I am a, I am Hello  ok, \n new line ffdsa!";
            System.out.println("before:"+str);
            Matcher m = p.matcher(str);
            String after = m.replaceAll(""); 
            System.out.println("after:"+after);
           }
           
           public static void main(String[] args) {
              replaceBlank();
            }

          posted @ 2008-05-13 02:42 u-s-soldiers 閱讀(512) | 評論 (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));

          }

          以上的執(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"},其實分割時還有跟簡單的方法:

          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"

          如果寫成空串,既可達到刪除的功能,比如:

          String s=m.replaceAll("");

          結(jié)果為"bbced  ccde"

          附:

          \d 等於 [0-9] 數(shù)字 
          \D 等於 [^0-9] 非數(shù)字 
          \s 等於 [ \t\n\x0B\f\r] 空白字元 
          \S 等於 [^ \t\n\x0B\f\r] 非空白字元 
          \w 等於 [a-zA-Z_0-9] 數(shù)字或是英文字 
          \W 等於 [^a-zA-Z_0-9] 非數(shù)字與英文字 

          ^ 表示每行的開頭
          $ 表示每行的結(jié)尾
          posted @ 2008-05-03 14:44 u-s-soldiers 閱讀(212) | 評論 (0)編輯 收藏

          主站蜘蛛池模板: 博罗县| 缙云县| 清新县| 盐源县| 周宁县| 麟游县| 宽城| 南安市| 收藏| 时尚| 尤溪县| 辉县市| 会同县| 丹巴县| 巫溪县| 汝南县| 上栗县| 昌平区| 彰化县| 新源县| 三穗县| 惠来县| 宁都县| 高阳县| 靖西县| 汾阳市| 隆林| 桓台县| 卓尼县| 怀远县| 阿勒泰市| 永兴县| 读书| 崇明县| 鹤庆县| 固镇县| 万年县| 大理市| 旅游| 斗六市| 托里县|