這篇文章將為大家詳細(xì)講解有關(guān)java中正則表達(dá)式基本用法是什么,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
專注于為中小企業(yè)提供成都網(wǎng)站制作、做網(wǎng)站服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)恭城免費做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了上千余家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。
java中正則表達(dá)式基本用法的使用:1、【Test01.java】使用正則表達(dá)式使代碼變得非常簡潔;2、【TestMatcher01.java】Matcher類的使用,用于字符串的驗證。
正則表達(dá)式是一種可以用于模式匹配和替換的規(guī)范,一個正則表達(dá)式就是由普通的字符(例如字符a到z)以及特殊字符(元字符)組成的文字模式,它用以描述在查找文字主體時待匹配的一個或多個字符串。正則表達(dá)式作為一個模板,將某個字符模式與所搜索的字符串進(jìn)行匹配。
眾所周知,在程序開發(fā)中,難免會遇到需要匹配、查找、替換、判斷字符串的情況發(fā)生,而這些情況有時又比較復(fù)雜,如果用純編碼方式解決,往往會浪費程序員的時間及精力。因此,學(xué)習(xí)及使用正則表達(dá)式,便成了解決這一矛盾的主要手段。
大家都知道,正則表達(dá)式是一種可以用于模式匹配和替換的規(guī)范,一個正則表達(dá)式就是由普通的字符(例如字符a到z)以及特殊字符(元字符)組成的文字模式,它 用以描述在查找文字主體時待匹配的一個或多個字符串。正則表達(dá)式作為一個模板,將某個字符模式與所搜索的字符串進(jìn)行匹配。
自從jdk1.4推出java.util.regex包,就為我們提供了很好的JAVA正則表達(dá)式應(yīng)用平臺。
因為正則表達(dá)式是一個很龐雜的體系,所以我僅例舉些入門的概念,更多的請參閱相關(guān)書籍及自行摸索。
*下面是java中正則表達(dá)式常用的語法:
1、字符的取值范圍
[abc] : 表示可能是a,可能是b,也可能是c。
[^abc]: 表示不是a,b,c中的任意一個
[a-zA-Z]: 表示是英文字母
[0-9]:表示是數(shù)字
2、簡潔的字符表示
.:匹配任意的字符
\d:表示數(shù)字
\D:表示非數(shù)字
\s:表示由空字符組成,[ \t\n\r\x\f]
\S:表示由非空字符組成,[^\s]
\w:表示字母、數(shù)字、下劃線,[a-zA-Z0-9_]
\W:表示不是由字母、數(shù)字、下劃線組成
3、數(shù)量表達(dá)式
?: 表示出現(xiàn)0次或1次
+: 表示出現(xiàn)1次或多次
*: 表示出現(xiàn)0次、1次或多次
{n}:表示出現(xiàn)n次
{n,m}:表示出現(xiàn)n~m次
{n,}:表示出現(xiàn)n次或n次以上
4、邏輯表達(dá)式
XY: 表示X后面跟著Y,這里X和Y分別是正則表達(dá)式的一部分
X|Y:表示X或Y,比如"food|f"匹配的是foo(d或f),而"(food)|f"匹配的是food或f
(X):子表達(dá)式,將X看做是一個整體
5、java中提供了兩個類來支持正則表達(dá)式的操作
分別是java.util.regex下的Pattern類和Matcher類
使用Pattern類進(jìn)行字符串的拆分,使用的方法是String[] split(CharSequence input)
使用Matcher類進(jìn)行字符串的驗證和替換,
匹配使用的方法是boolean matches()
替換使用的方法是 String replaceAll(String replacement)
6、Pattern類的構(gòu)造方法是私有的
所以我們使用Pattern p = Pattern.compile("a*b");進(jìn)行實例化
Matcher類的實例化依賴Pattern類的對象Matcher m = p.matcher("aaaaab");
7、在實際的開發(fā)中,為了方便我們很少直接使用Pattern類或Matcher類,而是使用String類下的方法
驗證:boolean matches(String regex)
拆分: String[] split(String regex)
替換: String replaceAll(String regex, String replacement)
下面是正則表達(dá)式的簡單使用:
1、Test01.java :使用正則表達(dá)式使代碼變得非常簡潔。
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){ //這里默認(rèn)郵箱的后綴是.com或.net.cn String str = "aa@aa.net.cn"; String regex = "\\w+@\\w+\\.(com|net.cn)"; System.out.println(str.matches(regex)); } }
關(guān)于java中正則表達(dá)式基本用法是什么就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。