更新時(shí)間:2019-09-04 11:47:45 來源:動(dòng)力節(jié)點(diǎn) 瀏覽2616次
今天動(dòng)力節(jié)點(diǎn)java培訓(xùn)機(jī)構(gòu)小編為java零基礎(chǔ)學(xué)員介紹“java正則表達(dá)式基本用法詳解”,希望大家通過此文能夠理解java正則表達(dá)式基本用法,下面就是小編一起看看java正則表達(dá)式基本用法詳解。
正則表達(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á)式,便成了解決這一矛盾的主要手段。
自從jdk1.4推出java.util.regex包,就為我們提供了很好的JAVA正則表達(dá)式應(yīng)用平臺。
下面是java中正則表達(dá)式常用的語法:
字符的取值范圍
[abc] : 表示可能是a,可能是b,也可能是c。
[^abc]: 表示不是a,b,c中的任意一個(gè)
[a-zA-Z]: 表示是英文字母
[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á)式
?: 表示出現(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次以上
邏輯表達(dá)式
XY: 表示X后面跟著Y,這里X和Y分別是正則表達(dá)式的一部分
X|Y:表示X或Y,比如"food|f"匹配的是foo(d或f),而"(food)|f"匹配的是food或f
(X):子表達(dá)式,將X看做是一個(gè)整體
java中提供了兩個(gè)類來支持正則表達(dá)式的操作,分別是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類的對象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)
下面是正則表達(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類的使用,用于字符串的驗(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培訓(xùn)機(jī)構(gòu)小編介紹的“java正則表達(dá)式基本用法詳解”的內(nèi)容,希望對大家有幫助,更多java資訊最新內(nèi)容請繼續(xù)關(guān)注動(dòng)力節(jié)點(diǎn)java培訓(xùn)機(jī)構(gòu)官網(wǎng),每天會(huì)有精彩內(nèi)容分享與你。
相關(guān)免費(fèi)視頻教程推薦
java基礎(chǔ)視頻教程下載——與正則表達(dá)式相關(guān)的操作:http://www.dabaquan.cn/xiazai/2516.html
相關(guān)閱讀
初級 202925
初級 203221
初級 202629
初級 203743