Mark's Java Blog
          MyEclipse, Java EE, Spring, Struts, Hibernate, JPA, SWT, Swing, AJAX, JavaScript,SOA
          正則表達式在字符串處理上有著強大的功能,sun在jdk1.4加入了對它的支持

          下面簡單的說下它的4種常用功能:

          查詢:

          String str="abc efg ABC";
          正則表達式在字符串處理上有著強大的功能,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] 數字 
          \D 等於 [^0-9] 非數字 
          \s 等於 [ \t\n\x0B\f\r] 空白字元 
          \S 等於 [^ \t\n\x0B\f\r] 非空白字元 
          \w 等於 [a-zA-Z_0-9] 數字或是英文字 
          \W 等於 [^a-zA-Z_0-9] 非數字與英文字 

          ^ 表示每行的開頭
          $ 表示每行的結尾

          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] 數字 
          \D 等於 [^0-9] 非數字 
          \s 等於 [ \t\n\x0B\f\r] 空白字元 
          \S 等於 [^ \t\n\x0B\f\r] 非空白字元 
          \w 等於 [a-zA-Z_0-9] 數字或是英文字 
          \W 等於 [^a-zA-Z_0-9] 非數字與英文字 

          ^ 表示每行的開頭
          $ 表示每行的結尾
          posted on 2008-04-01 14:02 Mark 閱讀(263) 評論(0)  編輯  收藏 所屬分類: Java SE
           
          主站蜘蛛池模板: 广水市| 青阳县| 砚山县| 申扎县| 福泉市| 东乡| 房山区| 海淀区| 高邑县| 海伦市| 平顺县| 海兴县| 岐山县| 晋江市| 静宁县| 吉隆县| 临江市| 兴义市| 丰台区| 东乡县| 施甸县| 西贡区| 武义县| 灵川县| 永昌县| 抚顺市| 岳西县| 汉川市| 临沧市| 绥江县| 正宁县| 石嘴山市| 杭锦后旗| 平遥县| 栾城县| 大理市| 南阳市| 卢龙县| 昌宁县| 海宁市| 张家川|