java 正則表達式規(guī)則是怎樣的?Java中如何寫正則表達式?
正則表達式,也叫做規(guī)則表達式,它是一個計算機領(lǐng)域的一個概念,它的作用就是檢索和替換符合某個規(guī)則的文本,有很多的語言都是支持正則表達式的,使用正則表達式來編寫代碼是非常的簡潔的,一般只需要兩行到三行的代碼就可以了,很多朋友想了解一下java 正則表達式的相關(guān)情況,下面新網(wǎng)就來具體的說明一下java 正則表達式規(guī)則是怎樣的?Java中如何寫正則表達式等問題。
1. 任意一個字符表示匹配任意對應(yīng)的字符,如a匹配a,7匹配7,-匹配-。
2. []代表匹配中括號中其中任一個字符,如[abc]匹配a或b或c。
3. -在中括號里面和外面代表含義不同,如在外時,就匹配-,如果在中括號內(nèi)[a-b]表示匹配26個小寫字母中的任一個;[a-zA-Z]匹配大小寫共52個字母中任一個;[0-9]匹配十個數(shù)字中任一個。
4. ^在中括號里面和外面含義不同,如在外時,就表示開頭,如^7[0-9]表示匹配開頭是7的,且第二位是任一數(shù)字的字符串;如果在中括號里面,表示除了這個字符之外的任意字符(包括數(shù)字,特殊字符),如[^abc]表示匹配出去abc之外的其他任一字符。
5. .表示匹配任意的字符。
6. \d表示數(shù)字。
7. \D表示非數(shù)字。
8.\s表示由空字符組成,[ \t\n\r\x\f]。
9.\S表示由非空字符組成,[^\s]。
10.\w表示字母、數(shù)字、下劃線,[a-zA-Z0-9_]。
11.\W表示不是由字母、數(shù)字、下劃線組成。
12.?: 表示出現(xiàn)0次或1次。
13.+表示出現(xiàn)1次或多次。
14.*表示出現(xiàn)0次、1次或多次。
15.{n}表示出現(xiàn)n次。
16.{n,m}表示出現(xiàn)n~m次。
17.{n,}表示出現(xiàn)n次或n次以上。
18.XY表示X后面跟著Y,這里X和Y分別是正則表達式的一部分。
19.X|Y表示X或Y,比如"food|f"匹配的是foo(d或f),而"(food)|f"匹配的是food或f。
20.(X)子表達式,將X看做是一個整體。
在java中調(diào)用正則表達式的類是java.util.regex.Matcher和java.util.regex.Pattern,java.util.regex包是從jdk1.4開始提供的。有多種寫法來使用正則表達式。
1. 僅僅是匹配
1). 實現(xiàn)方式1,匹配一個數(shù)字。
public void regex1() {
//要匹配的字符
String str = "8";
//正則表達式
String regex = "[0-9]";
//返回匹配的結(jié)果,匹配成功就返回true,失敗就返回false,此次匹配返回true。
boolean flag = Pattern.matches(regex, str);
System.out.println(flag);
}
2). 實現(xiàn)方式2, 匹配3個到5個字母,大小寫不限,包括3和5個。
public void regex2() {
//要匹配的字符
String str = "hello";
//正則表達式
String regex = "[a-zA-Z]{3,5}";
//輸出匹配的結(jié)果, 此次匹配返回true。
System.out.println(str.matches(regex));
}
3). 實現(xiàn)方式3(此種實現(xiàn)方式最快), 匹配11位的電話號碼,匹配規(guī)則:第一個數(shù)字是1,第二個數(shù)字是2,3,7,8中任一個,后面9位數(shù)字中不包含4。
public void regex3() {
//要匹配的字符
String str = "13656231253";
//正則表達式
String regex = "1[2378][0-35-9]{9}";
//將給定的正則表達式編譯為模式。 如果匹配需求較多,且需用同相同的regex去匹配,就可將這句寫到靜態(tài)模塊里面,用的時候直接使用實例p
Pattern p = Pattern.compile(regex);
//創(chuàng)建一個匹配器,匹配給定的輸入與此模式。
Matcher m = p.matcher(str);
//嘗試將整個區(qū)域與模式進行匹配。
boolean flag = m.matches();
//輸出匹配結(jié)果,此次結(jié)果為true
System.out.println(flag);
}
2. 替換。
public void regexReplace () {
//要匹配的字符
String str = "12a6B985Ccv65";
//正則表達式
String regex = "[a-zA-Z]+";
//正則表達式
String regex2 = "\\d+";
//將字符串中英文字母替換為&符號,輸出12&6&985&65
System.out.println(str.replaceAll(regex, "&"));
//將字符串中單個數(shù)字或者連續(xù)的數(shù)字替換為0,輸出0a0B0Ccv0
System.out.println(str.replaceAll(regex2,"0"));
}
3. 切割,根據(jù)大寫字母切割字符串。
public void outputStr() {
String str = "oneTtowTthreeDfourJfive";
String regex = "[A-Z]";
String[] arr = str.split(regex);
for (String s: arr) {
System.out.print(s + " ");
}
}
輸出:one tow three four five。
java 正則表達式的特點
1. 靈活性、邏輯性和功能性非常強;
2. 可以迅速地用極簡單的方式達到字符串的復(fù)雜控制。
3. 對于剛接觸的人來說,比較晦澀難懂。
由于正則表達式主要應(yīng)用對象是文本,因此它在各種文本編輯器場合都有應(yīng)用,小到著名編輯器EditPlus,大到Microsoft Word、Visual Studio等大型編輯器,都可以使用正則表達式來處理文本內(nèi)容。
<div>
聲明:免責(zé)聲明:本文內(nèi)容由互聯(lián)網(wǎng)用戶自發(fā)貢獻自行上傳,本網(wǎng)站不擁有所有權(quán),也不承認相關(guān)法律責(zé)任。如果您發(fā)現(xiàn)本社區(qū)中有涉嫌抄襲的內(nèi)容,請發(fā)
送郵件至:operations@xinnet.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,本站將立刻刪除涉嫌侵權(quán)內(nèi)容。本站原創(chuàng)內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時
需注明出處:新網(wǎng)idc知識百科