<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

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

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

    查詢:

    String str="abc efg ABC";
    正則表達(dá)式在字符串處理上有著強(qiáng)大的功能,sun在jdk1.4加入了對(duì)它的支持

    下面簡單的說下它的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。如果想在查找時(shí)忽略大小寫,則可以寫成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,提取的字符串儲(chǔ)存在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í)分割時(shí)還有跟簡單的方法:

    String str="xd::abc::cde";

    String[] r=str.split("::");

    替換(刪除):

    String regEx="a+"; //表示一個(gè)或多個(gè)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ù)字 
    \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é)尾

    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。如果想在查找時(shí)忽略大小寫,則可以寫成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,提取的字符串儲(chǔ)存在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í)分割時(shí)還有跟簡單的方法:

    String str="xd::abc::cde";

    String[] r=str.split("::");

    替換(刪除):

    String regEx="a+"; //表示一個(gè)或多個(gè)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ù)字 
    \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 on 2008-04-01 14:02 Mark 閱讀(263) 評(píng)論(0)  編輯  收藏 所屬分類: Java SE
     
    主站蜘蛛池模板: 亚洲精品乱码久久久久久久久久久久 | www视频免费看| 亚洲免费观看视频| 亚洲成在人天堂在线| 亚洲人成网站在线播放2019 | 亚洲一级毛片免观看| 亚洲毛片免费观看| 亚洲免费无码在线| 一级一级一片免费高清| 亚洲国产小视频精品久久久三级| 国产亚洲高清在线精品不卡| 精品视频在线免费观看| 日韩高清免费在线观看| 亚洲欧洲专线一区| 四虎精品亚洲一区二区三区| 一级视频免费观看| 亚洲国产精品无码一线岛国| 一本久久免费视频| 免费无码又黄又爽又刺激| 亚洲综合精品第一页| 亚洲av无码成人精品区| 成人无码a级毛片免费| 色拍自拍亚洲综合图区| 青青草免费在线视频| 特级毛片免费播放| 午夜成人免费视频| 欧亚一级毛片免费看| 国产又粗又猛又爽又黄的免费视频| 亚洲狠狠ady亚洲精品大秀| 女人张开腿给人桶免费视频| 4hu四虎免费影院www| 亚洲成A∨人片天堂网无码| a视频免费在线观看| 亚洲成a人片在线网站| 色猫咪免费人成网站在线观看| 91亚洲视频在线观看| 亚洲免费在线视频| 亚洲成a人片在线观看天堂无码 | 亚洲最大中文字幕| 免费人成视网站在线观看不卡| 久久国产免费一区二区三区 |