總網頁瀏覽量

2012年5月24日 星期四

JAVA 正則表示式


正則表達式: 符合一定規則的表達式
用於專門操作字串,用一些特定的符號來表示一些代碼操作,簡化程式碼
//對號碼進行校驗
//長度5~15, 0不可第一位, 只可數字
class Hello{

    public static void main(String[] args){

       String num = "123448940";

       int len = num.length();

       if(len >= 5 && len <= 15){

           if(!num.startsWith("0")){

              char[] arr = num.toCharArray();

              boolean flag = true;

              for(int x = 0; x < arr.length; x++){

                  if(!(arr[x] >= '0' && arr[x] <= '9')){

                     flag = false;

                     break;

                  }

              }

              if(flag){

                  System.out.println("num: " + num);

              }else{

                  System.out.println("請輸入數字");

              }

           }else{

              System.out.println("不可0開頭");

           }

       }else{

           System.out.println("長度不符");

       }

    }

}

改良:
//對號碼進行校驗
//長度5~15, 0不可第一位, 只可數字
class Hello{

    public static void main(String[] args){   

       checkNum();

    }

    public static void checkNum(){

       String num = "151651651";

       //規則 第一位[1-9], 第二位以後[0-9] 出現次數{4,14}

       String regex = "[1-9][0-9]{4,14}";

       boolean flag = num.matches(regex);

       if(flag){

           System.out.println("OK");

       }else{

           System.out.println("No");

       }

    }

}


操作功能
1.  匹配: String matches方法
[bcd] 第一個字元只能是b, c, d,並且只能有一個字元
[a-zA-Z][0-9] 第一位為字母,第二位為數字
[^abc]第一位不可a, b, c
[a-c[e-g]] aceg
[a-g&&[b-d]] b,c,d 交集

\d 也可以表示輸入為[0-9],使用時要注意特殊符號
\D 表示[^0-9]
\s 表示空白字元
\S表示非空白字元
\w 表示數字或英文字

\W表示非數字或非英文字

public class Main{

    public static void main(String[] args){

       demo();

    }

    public static void demo(){

       String str = "b5";

       String reg = "[bcd][\\d]";

       boolean b = str.matches(reg);

       System.out.println(b);//ture

    }

}

Greedy
X?:  X值出現一次或零次(完全沒有, 空字元)
X*:  X值出現零次或多次
X+:  X值出現一次或多次
X{n}:  X恰好n
X{n, }: X至少n
X{n,m}:X至少n次,但不超過m

    public static void testString(){
    String a = "11 2";
    String b = "2";
    String c = "22";
    String reg1 = "2?";
    p(a.matches(reg1));//false
    p(b.matches(reg1));//true
    p(c.matches(reg1));//false
   
    String reg2 = "2*";
    p(a.matches(reg2));//false
    p(b.matches(reg2));//true
    p(c.matches(reg2));//true

    String reg3 = "2+";
    p(a.matches(reg3));//false
    p(b.matches(reg3));//true
    p(c.matches(reg3));//true
   
    String reg4 = "2{1}";
    p(a.matches(reg4));//false
    p(b.matches(reg4));//true
    p(c.matches(reg4));//false
    }


2.  切割 split
public class Main{

    public static void main(String[] args){

       demo();

    }

    public static void demo(){

       String str = "a,b,c,d,e,f";

       String reg = ",";

       String[] strArray = str.split(reg);

       for(String s: strArray){

           System.out.println(s);

       }

    }

}

空格切割:
String str = "sqss   erfr    rferfer";
String reg = " +";  //空格出現一次或多次!

.切割
String str = "dwdaqwd.d.wd.wf.wqfq.wf";
String reg = "\\."; //.是特殊符號,必須先轉譯

特殊:
String str = "c:\\dwdqw\\dqda\\a.txt";
String reg = "\\\\";

特殊: 以疊字分割
String str = "daggegffftyvvvrs";
String reg = "(.)\\1+";
讓這個規則被蟲用,可以將規則封裝成一組,用()完成,組的出現會有編號,從1開始,想要使用已有的組可以通過 \n(n就是組的編號)的形式來獲取

3.替換 replaceAllreplace(String類別)
public class Main{

    public static void main(String[] args){

       demo();

    }

    public static void demo(){

       String str = "swdwdw46846232def48ce8f4";

       String reg = "\\d{5,}";//替換規則

       String newStr = "#";//替換為此字串

      

       String resultString = str.replaceAll(reg, newStr);

       System.out.println(resultString);

    }

}


將疊字換成單個字母 zzz -> z
String str = "swwwffrffevvvtthjyjyrrr";
String reg = "(.)\\1+";//替換規則
String newStr = "$1";//替換為此字串 $使用前一組的規則
String resultString = str.replaceAll(reg, newStr);

4.獲取:將字串中符合規則的子字串取出
將正則表達式封裝成物件
讓正則物件和要操作的字串相關聯
關聯後,獲取正則匹配引擎
通過引擎對符合規則的子字串進行操作,例如取出
class Hello{

    public static void main(String[] args){   

       demo();

    }

    public static void demo(){

       String str = "kab jio jeioj joijio skl";

       String reg = "\\b[a-z]{3}\\b";

       //將規則封裝成物件

       Pattern p = Pattern.compile(reg);

       //讓正則物件與要作用的字串相關聯

       Matcher m = p.matcher(str);

       //System.out.println(m.matches());

       //String類中的matches方法,即使用PatternMatcher類的matcher方法

       //只不過String方法封裝後, 使用較簡單, 但功能一致

      

       //將規則作用到字串上, 並進行符合規則的子串查找

       while(m.find()){

           System.out.print(m.group() + " ");//用於獲取匹配後結果

           //kab //jio  //skl

           System.out.println(m.start() + "..." + m.end());

           //0...3  //4...7  /21...24

       }

    }

}

1.  如果只想知道該字串是對或錯,使用匹配
2.  想要將已有的字串轉變成另一個字串,替換
3.  想要按照自定的方式將字串變成多個字串,切割。獲取規則外的子串
4.  想要拿到符合需求的字串中的子串,獲取。獲取符合規則的子串
class Hello{

    public static void main(String[] args){   

       demo();

    }

    public static void demo(){

       String str = "aaa..aa...ab...bb..bbb..ccc..cc.ddd...dd.d..ee";

       str = str.replaceAll("\\.+", "");

       System.out.println(str);//aaaaaabbbbbbcccccddddddee

       str = str.replaceAll("(.)\\1+", "$1");//去疊字

       System.out.println(str);//abcde

    }

}

檢查mail是否符合規則
class Hello{

    public static void main(String[] args){   

       checkMail();

    }

    public static void checkMail(){

       String mail = "abcdefg@google.com.te";

       String reg = "[a-zA-Z0-9_]{6,12}@[a-zA-Z0-9]+(\\.[a-zA-Z]+){1,3}";

       System.out.println(mail.matches(reg));

    }

}



沒有留言:

張貼留言