您好,登錄后才能下訂單哦!
本篇內(nèi)容介紹了“JAVA正則表達(dá)式和字符串的替換與分解的應(yīng)用方法”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
Java 提供了 java.util.regex
包來(lái)與正則表達(dá)式進(jìn)行模式匹配java.util.regex
包主要包括以下三個(gè)類:
Pattern 類:
pattern 對(duì)象是一個(gè)正則表達(dá)式的編譯表示。Pattern 類沒(méi)有公共構(gòu)造方法。要?jiǎng)?chuàng)建一個(gè) Pattern 對(duì)象,你必須首先調(diào)用其公共靜態(tài)編譯方法,它返回一個(gè) Pattern 對(duì)象。該方法接受一個(gè)正則表達(dá)式作為它的第一個(gè)參數(shù)。
Matcher 類:
Matcher 對(duì)象是對(duì)輸入字符串進(jìn)行解釋和匹配操作的引擎。與Pattern 類一樣,Matcher 也沒(méi)有公共構(gòu)造方法。你需要調(diào)用 Pattern 對(duì)象的 matcher 方法來(lái)獲得一個(gè) Matcher 對(duì)象。
.
:表示任何一個(gè)字符
\d :\\d
表示0~9任何一個(gè)字符 \D:非0~9任何一個(gè)字符
\s :\\s
表示空格類字符
\w:\\w
表示可用于標(biāo)識(shí)符的字符(不包含美元符號(hào))
\p{lower}:\\p {lower}
表示小寫(xiě)字母a—z
\p{upper}:\\p{upper}
表示大寫(xiě)字母
\p{ascll}:\\p{ascll}
表示ascll字符
\p{punct}:\\p{punct}
表示標(biāo)點(diǎn)符號(hào)
[abc]
:表示a b c 中的任何一個(gè)
[^abc]
:表示除去 a b c 以外的任何字符
[a-zA-Z]:
表示英文字母中的其中一個(gè)?
表示元字符或者普通字符,表示出現(xiàn)0次或者1次
X?
:表示X出現(xiàn)0次或者1次
X*
: 表示X出現(xiàn)0次或者無(wú)數(shù)次
X+
:表示 X出現(xiàn)1次或者多次
X{n}
:表示X恰好出現(xiàn)n次
X{n,}
:表示X至少出現(xiàn)n次
X{n,m}
:表示X出現(xiàn)n次至m次
replaceAll
方法返回一個(gè)字符串,但是不改變當(dāng)前字符串
String result= "12hello567".replaceAll("\\d+"," 你好 "); 你好hello 你好
public class ReplaceErrorWord { public static void main(String args[ ]) { String str = "登錄網(wǎng)站: 222.128.89.253"; Pattern pattern; Matcher matcher; String regex = "[\\d]{1,3}[.][\\d]{1,3}[.][\\d]{1,3}[.][\\d]{1,3}"; pattern = Pattern.compile(regex);//使用 regex 初試化模式對(duì)象 pattern matcher = pattern.matcher(str);//得到檢索 str 的匹配對(duì)象 matcher String IP=""; while(matcher.find()) { IP= matcher.group(); System.out.print(matcher.start()+"位置出現(xiàn):"); System.out.println(IP); } System.out.printf("將%s 替換為 202.192.78.56\n",IP); String result = matcher.replaceAll("202.192.78.56"); System.out.println(result); } }
split()
import java.util.Scanner; public class Xi{ public static void main(String[] args){ System.out.println("請(qǐng)輸入一行文本:"); Scanner reader=new Scanner(System.in); String str=reader.nextLine(); String regex = "[\\s\\d\\p{Punct}]"; String words[]=str.split(regex); for(int i = 0;i < words.length;i++){ int m=i+1; System.out.println("單詞"+m+";"+words[i]); } } }
“JAVA正則表達(dá)式和字符串的替換與分解的應(yīng)用方法”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。