溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

java正則表達式的使用方法

發(fā)布時間:2020-06-15 15:17:58 來源:億速云 閱讀:173 作者:元一 欄目:編程語言

正則表達式概念:

正則表達式是對字符串操作的一種邏輯公式,就是用事先定義好的一些特定字符、及這些特定字符的組合,組成一個"規(guī)則字符串",這個"規(guī)則字符串"用來表達對字符串的一種過濾邏輯。

自從jdk1.4推出java.util.regex包,就為我們提供了很好的JAVA正則表達式應(yīng)用平臺。

因為正則表達式是一個很龐雜的體系,所以我僅例舉些入門的概念,更多的請參閱相關(guān)書籍及自行摸索。

*下面是java中正則表達式常用的語法:

字符的取值范圍
1.[abc] : 表示可能是a,可能是b,也可能是c。
2.[^abc]: 表示不是a,b,c中的任意一個
3.[a-zA-Z]: 表示是英文字母
4.[0-9]:表示是數(shù)字

簡潔的字符表示
.:匹配任意的字符
\d:表示數(shù)字
\D:表示非數(shù)字
\s:表示由空字符組成,[ \t\n\r\x\f]
\S:表示由非空字符組成,[^\s]
\w:表示字母、數(shù)字、下劃線,[a-zA-Z0-9_]
\W:表示不是由字母、數(shù)字、下劃線組成

數(shù)量表達式
1.?: 表示出現(xiàn)0次或1次
2.+: 表示出現(xiàn)1次或多次
3.*: 表示出現(xiàn)0次、1次或多次
4.{n}:表示出現(xiàn)n次
5.{n,m}:表示出現(xiàn)n~m次
6.{n,}:表示出現(xiàn)n次或n次以上

邏輯表達式
1.XY: 表示X后面跟著Y,這里X和Y分別是正則表達式的一部分
2.X|Y:表示X或Y,比如"food|f"匹配的是foo(d或f),而"(food)|f"匹配的是food或f
3.(X):子表達式,將X看做是一個整體

java中提供了兩個類來支持正則表達式的操作
分別是java.util.regex下的Pattern類和Matcher類
使用Pattern類進行字符串的拆分,使用的方法是String[] split(CharSequence input)
使用Matcher類進行字符串的驗證和替換,
匹配使用的方法是boolean matches()
替換使用的方法是 String replaceAll(String replacement)

Pattern類的構(gòu)造方法是私有的
所以我們使用Pattern p = Pattern.compile("a*b");進行實例化
Matcher類的實例化依賴Pattern類的對象Matcher m = p.matcher("aaaaab");

在實際的開發(fā)中,為了方便我們很少直接使用Pattern類或Matcher類,而是使用String類下的方法
驗證:boolean matches(String regex)
拆分: String[] split(String regex)
替換: String replaceAll(String regex, String replacement)

下面是正則表達式的簡單使用:
1、Test01.java :使用正則表達式使代碼變得非常簡潔。

package test_regex;
public class Test01 {
    public static void main(String[] args){
        String str = "1234567";
//        char[] c = str.toCharArray();
//        boolean b = true;
//        for(char c1:c){
//            if(!(c1>='0'&&c1<='9')){
//                b = false;
//                break;
//            }
//        }
//        System.out.println(b);

        String regex = "\\d+";
        System.out.println(str.matches(regex));
    }
}

2、TestMatcher01.java(Matcher類的使用,用于字符串的驗證)

package test_regex;
import java.util.regex.Pattern;
import java.util.regex.Matcher;
public class TestMatcher01 {
    public static void main(String[] args){
        String str = "1234567abc";
        String regex = "\\w{10,}";
//        Pattern pat = Pattern.compile(regex);
//        Matcher mat = pat.matcher(str);
//        System.out.println(mat.matches());
        System.out.println(str.matches(regex));
    }
}

3、TestMatcher02.java(Matcher類的使用,用于字符串的替換)

package test_regex;
import java.util.regex.Pattern;
import java.util.regex.Matcher;
public class TestMatcher02 {
    public static void main(String[] args){
        String str = "12Y34h66dAd7";
        String regex = "[a-zA-Z]+";
//        Pattern pat = Pattern.compile(regex);
//        Matcher mat = pat.matcher(str);
//        System.out.println(mat.replaceAll(":"));
        System.out.println(str.replaceAll(regex,"-"));
    }
}

4、TestPattern01.java(Pattern類的使用,用于字符串的拆分)

package test_regex;
import java.util.regex.Pattern;
public class TestPattern01 {
    public static void main(String[] args){
        String str = "Tom:30|Jerry:20|Bob:25";
        String regex = "\\|";
//        Pattern pat = Pattern.compile(regex);
//        String[] arr = pat.split(str);
        String[] arr = str.split(regex);
        for(String s:arr){
            System.out.println(s);
        }
    }
}

5、TestRegex01.java(大概判斷一個郵箱地址是否合法)

package test_regex;
public class TestRegex01 {
    //判斷一個郵箱地址是否合法
    public static void main(String[] args){
        //這里默認郵箱的后綴是.com或.net.cn
        String str = "aa@aa.net.cn";
        String regex = "\\w+@\\w+\\.(com|net.cn)";
        System.out.println(str.matches(regex));
    }
}

以上就是java正則表達式的用法是什么的詳細內(nèi)容,更多請關(guān)注億速云其它相關(guān)文章!

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI