更新時(shí)間:2021-05-27 16:13:58 來源:動(dòng)力節(jié)點(diǎn) 瀏覽1237次
正則表達(dá)式是一種可以用于模式匹配和替換的規(guī)范,一個(gè)正則表達(dá)式就是由普通的字符(例如字符a到z)以及特殊字符(元字符)組成的文字模式,它用以描述在查找文字主體時(shí)待匹配的一個(gè)或多個(gè)字符串。正則表達(dá)式作為一個(gè)模板,將某個(gè)字符模式與所搜索的字符串進(jìn)行匹配。
眾所周知,在程序開發(fā)中,難免會(huì)遇到需要匹配、查找、替換、判斷字符串的情況發(fā)生,而這些情況有時(shí)又比較復(fù)雜,如果用純編碼方式解決,往往會(huì)浪費(fèi)程序員的時(shí)間及精力。因此,學(xué)習(xí)及使用正則表達(dá)式,便成了解決這一矛盾的主要手段。
大家都知道,正則表達(dá)式是一種可以用于模式匹配和替換的規(guī)范,一個(gè)正則表達(dá)式就是由普通的字符(例如字符a到z)以及特殊字符(元字符)組成的文字模式,它用以描述在查找文字主體時(shí)待匹配的一個(gè)或多個(gè)字符串。正則表達(dá)式作為一個(gè)模板,將某個(gè)字符模式與所搜索的字符串進(jìn)行匹配。
自從jdk1.4推出java.util.regex包,就為我們提供了很好的Java正則表達(dá)式應(yīng)用平臺(tái)。
因?yàn)檎齽t表達(dá)式是一個(gè)很龐雜的體系,所以我僅例舉些入門的概念,更多的請(qǐng)參閱相關(guān)書籍及自行摸索。
1.[abc]:表示可能是a,可能是b,也可能是c。
2.[^abc]:表示不是a,b,c中的任意一個(gè)
3.[a-zA-Z]:表示是英文字母
4.[0-9]:表示是數(shù)字
.:匹配任意的字符
d:表示數(shù)字
D:表示非數(shù)字
s:表示由空字符組成,[tnrxf]
S:表示由非空字符組成,[^s]
w:表示字母、數(shù)字、下劃線,[a-zA-Z0-9_]
W:表示不是由字母、數(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分別是正則表達(dá)式的一部分
2.X|Y:表示X或Y,比如"food|f"匹配的是foo(d或f),而"(food)|f"匹配的是food或f
3.(X):子表達(dá)式,將X看做是一個(gè)整體
分別是java.util.regex下的Pattern類和Matcher類
使用Pattern類進(jìn)行字符串的拆分,使用的方法是String[]split(CharSequence input)
使用Matcher類進(jìn)行字符串的驗(yàn)證和替換,
匹配使用的方法是boolean matches()
替換使用的方法是String replaceAll(String replacement)
Pattern類的構(gòu)造方法是私有的
所以我們使用Pattern p=Pattern.compile("a*b");進(jìn)行實(shí)例化
Matcher類的實(shí)例化依賴Pattern類的對(duì)象Matcher m=p.matcher("aaaaab");
在實(shí)際的開發(fā)中,為了方便我們很少直接使用Pattern類或Matcher類,而是使用String類下的方法
驗(yàn)證:boolean matches(String regex)
拆分:String[]split(String regex)
替換:String replaceAll(String regex,String replacement)
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類的使用,用于字符串的驗(yàn)證)
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 = "12Y34h56dAd7";
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(大概判斷一個(gè)郵箱地址是否合法)
package test_regex;
public class TestRegex01 {
//判斷一個(gè)郵箱地址是否合法
public static void main(String[] args){
//這里默認(rèn)郵箱的后綴是.com或.net.cn
String str = "[email protected]";
String regex = "\\w+@\\w+\\.(com|net.cn)";
System.out.println(str.matches(regex));
}
}
以上就是動(dòng)力節(jié)點(diǎn)小編介紹的"Java正則表達(dá)式的基本用法",希望對(duì)大家有幫助,如有疑問,請(qǐng)?jiān)诰€咨詢,有專業(yè)老師隨時(shí)為您服務(wù)。
0基礎(chǔ) 0學(xué)費(fèi) 15天面授
有基礎(chǔ) 直達(dá)就業(yè)
業(yè)余時(shí)間 高薪轉(zhuǎn)行
工作1~3年,加薪神器
工作3~5年,晉升架構(gòu)
提交申請(qǐng)后,顧問老師會(huì)電話與您溝通安排學(xué)習(xí)
初級(jí) 202925
初級(jí) 203221
初級(jí) 202629
初級(jí) 203743