這篇文章給大家分享的是有關(guān)java如何使用正則表達(dá)式的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考。一起跟隨小編過來看看吧。
創(chuàng)新互聯(lián)堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都做網(wǎng)站、成都網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的邵陽網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!java正則表達(dá)式用法:1、使用Pattern類進行字符串的拆分,使用的方法是【String[] split(CharSequence input)】;2、使用Matcher類進行字符串的驗證和替換。
java正則表達(dá)式用法:
正則表達(dá)式是一種可以用于模式匹配和替換的規(guī)范,一個正則表達(dá)式就是由普通的字符(例如字符a到z)以及特殊字符(元字符)組成的文字模式,它 用以描述在查找文字主體時待匹配的一個或多個字符串。正則表達(dá)式作為一個模板,將某個字符模式與所搜索的字符串進行匹配。
一個正則表達(dá)式就是由普通的字符(例如字符a到z)以及特殊字符(元字符)組成的文字模式,它 用以描述在查找文字主體時待匹配的一個或多個字符串。正則表達(dá)式作為一個模板,將某個字符模式與所搜索的字符串進行匹配。
*下面是java中正則表達(dá)式常用的語法:
字符的取值范圍 1.[abc] : 表示可 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ù)量表達(dá)式 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次以上 邏輯表達(dá)式 1.XY: 表示X后面跟著Y,這里X和Y分別是正則表達(dá)式的一部分 2.X|Y:表示X或Y,比如"food|f"匹配的是foo(d或f),而"(food)|f"匹配的是food或f 3.(X):子表達(dá)式,將X看做是一個整體 java中提供了兩個類來支持正則表達(dá)式的操作 分別是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)
下面是正則表達(dá)式的簡單使用:
1、Test01.java :使用正則表達(dá)式使代碼變得非常簡潔。
1 package test_regex; 2 public class Test01 { 3 public static void main(String[] args){ 4 String str = "1234567"; 5 // char[] c = str.toCharArray(); 6 // boolean b = true; 7 // for(char c1:c){ 8 // if(!(c1>='0'&&c1<='9')){ 9 // b = false; 10 // break; 11 // } 12 // } 13 // System.out.println(b); 14 15 String regex = "\\d+"; 16 System.out.println(str.matches(regex)); 17 } 18 }
2、TestMatcher01.java(Matcher類的使用,用于字符串的驗證)
1 package test_regex; 2 import java.util.regex.Pattern; 3 import java.util.regex.Matcher; 4 public class TestMatcher01 { 5 public static void main(String[] args){ 6 String str = "1234567abc"; 7 String regex = "\\w{10,}"; 8 // Pattern pat = Pattern.compile(regex); 9 // Matcher mat = pat.matcher(str); 10 // System.out.println(mat.matches()); 11 System.out.println(str.matches(regex)); 12 } 13 }
3、TestMatcher02.java(Matcher類的使用,用于字符串的替換)
1 package test_regex; 2 import java.util.regex.Pattern; 3 import java.util.regex.Matcher; 4 public class TestMatcher02 { 5 public static void main(String[] args){ 6 String str = "12Y34h66dAd7"; 7 String regex = "[a-zA-Z]+"; 8 // Pattern pat = Pattern.compile(regex); 9 // Matcher mat = pat.matcher(str); 10 // System.out.println(mat.replaceAll(":")); 11 System.out.println(str.replaceAll(regex,"-")); 12 } 13 }
4、TestPattern01.java(Pattern類的使用,用于字符串的拆分)
1 package test_regex; 2 import java.util.regex.Pattern; 3 public class TestPattern01 { 4 public static void main(String[] args){ 5 String str = "Tom:30|Jerry:20|Bob:25"; 6 String regex = "\\|"; 7 // Pattern pat = Pattern.compile(regex); 8 // String[] arr = pat.split(str); 9 String[] arr = str.split(regex); 10 for(String s:arr){ 11 System.out.println(s); 12 } 13 } 14 }
5、TestRegex01.java(大概判斷一個郵箱地址是否合法)
1 package test_regex; 2 public class TestRegex01 { 3 //判斷一個郵箱地址是否合法 4 public static void main(String[] args){ 5 //這里默認(rèn)郵箱的后綴是.com或.net.cn 6 String str = "aa@aa.net.cn"; 7 String regex = "\\w+@\\w+\\.(com|net.cn)"; 8 System.out.println(str.matches(regex)); 9 } 10 }
感謝各位的閱讀!關(guān)于java如何使用正則表達(dá)式就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!