真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Java中怎么用正則表達(dá)式

這篇文章將為大家詳細(xì)講解有關(guān)Java中怎么用正則表達(dá)式,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

坡頭網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)!從網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)公司等網(wǎng)站項(xiàng)目制作,到程序開發(fā),運(yùn)營維護(hù)。創(chuàng)新互聯(lián)于2013年成立到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)。

學(xué)習(xí)正則表達(dá)式,用Jdk1.4后的java.util.regex

模式:

我們來看一些更常用的表達(dá)式的種類

文字(Literal):表達(dá)式內(nèi)任何不具有特殊意義的字符都被看作是一個(gè)文字,并與自身匹配。

量詞(Quantifier):某些字符或表達(dá)式,它們被用來計(jì)算一個(gè)文字或分組可以在字符序列中出現(xiàn)的次

數(shù),以便該序列與表達(dá)式匹配。分組是由圓括號內(nèi)的一組字符指定的。
? 表示出現(xiàn)一次或根本不出現(xiàn)
* 表示出現(xiàn)零次或一次以上(含一次)
+ 表示出現(xiàn)一次或多次

字符類(Character class):一個(gè)字符類就是方括號內(nèi)的一個(gè)字符集,其中,匹配可以是括號內(nèi)的任意

一個(gè)字符。您可以把字符類與量詞結(jié)合在一起,例如, [acegikmoqsuwy]* 將是只包含字母表中奇數(shù)字

母的任意字符序列。某些字符類是預(yù)先定義的:
d ― 數(shù)字(0 到 9)
D -- 非數(shù)字
s -- 空白字符,如制表符或換行符
S -- 非空白字符
w -- 單字字符(a 到 z、A 到 Z、0 到 9 以及下劃線)
W -- 非單字字符(其它任意字符)

Posix 字符類(Posix character class):某些字符類僅在用于 US-ASCII 比較時(shí)才有效。例如:
p{Lower} ― 小寫字符
p{Upper} ― 大寫字符
p{ASCII} ― 所有 ASCII 字符
p{Alpha} ― 字母字符(p{Lower} 與 p{Upper} 相結(jié)合)
p{Digit} ― 從 0 到 9 的數(shù)字
p{Alnum} ― 字母數(shù)字字符

范圍(Range):使用短線(dash)來指定包括一定范圍字符的字符類。例如, [A-J] 表示從 A 到 J

的大寫字母

否定(Negation):脫字符(^)否定字符類的內(nèi)容。例如, [^A-J] 表示除 A 到 J 之外的任何字符。

反斜杠字符()在 String 常量中需要轉(zhuǎn)義。
w+ 與 p{Alnum}+ 類似,但添加了下劃線(_)。
反斜杠( .)代表句點(diǎn)。如果前面沒有反斜杠,單獨(dú)一個(gè)句點(diǎn)代表任意字符。
p{Alpha}{2, 3} 表示兩個(gè)或三個(gè)字母字符


--------------------------------------------------------------------------------
java.util.regex是一個(gè)用正則表達(dá)式所訂制的模式來對字符串進(jìn)行匹配工作的類庫包(其他:如

Jakarta-ORO )


它包括兩個(gè)類: Pattern和 Matcher

Pattern  一個(gè)Pattern是一個(gè)正則表達(dá)式經(jīng)編譯后的表現(xiàn)模式。
Matcher  一個(gè)Matcher對象是一個(gè)狀態(tài)機(jī)器,它依據(jù)Pattern對象做為匹配模式對字符串展開匹配檢查。

一個(gè)正則表達(dá)式,也就是一串有特定意義的字符,必須首先要編譯成為一個(gè)Pattern類的實(shí)例,這個(gè)

Pattern對象將會使用 matcher()方法來生成一個(gè)Matcher實(shí)例,接著便可以使用該 Matcher實(shí)例以編譯

的正則表達(dá)式為基礎(chǔ)對目標(biāo)字符串進(jìn)行匹配工作,多個(gè)Matcher是可以共用一個(gè)Pattern對象的。

在java.util.regex包里,我們僅需生成一個(gè)Pattern類,直接使用它的compile()

一個(gè)Matcher實(shí)例是被用來對目標(biāo)字符串進(jìn)行基于既有模式(也就是一個(gè)給定的Pattern所編譯的正則表

達(dá)式)進(jìn)行匹配查找的,所有往Matcher的輸入都是通過CharSequence接口提供的,這樣做的目的在于可

以支持對從多元化的數(shù)據(jù)源所提供的數(shù)據(jù)進(jìn)行匹配工作。

★matches()/lookingAt ()/find():
一個(gè)Matcher對象是由一個(gè)Pattern對象調(diào)用其matcher()方法而生成的,一旦該Matcher對象生成,它就可

以進(jìn)行三種不同的匹配查找操作:

matches()方法嘗試對整個(gè)目標(biāo)字符展開匹配檢測,也就是只有整個(gè)目標(biāo)字符串完全匹配時(shí)才返回真值。
lookingAt ()方法將檢測目標(biāo)字符串是否以匹配的子串起始。
find()方法嘗試在目標(biāo)字符串里查找下一個(gè)匹配子串。
以上三個(gè)方法都將返回一個(gè)布爾值來表明成功與否。

★replaceAll ()/appendReplacement()/appendTail():
Matcher類同時(shí)提供了四個(gè)將匹配子串替換成指定字符串的方法:

replaceAll()
replaceFirst()
appendReplacement()
appendTail()

使用方式
1。Pattern wordBreakPattern = Pattern.compile("模式");
2。Matcher lineMatcher = linePattern.matcher(需要匹配的字符串);
3。Match的函數(shù)如find/lookat等,檢查結(jié)果

關(guān)于“Java中怎么用正則表達(dá)式”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯(cuò),請把它分享出去讓更多的人看到。


分享標(biāo)題:Java中怎么用正則表達(dá)式
文章源于:http://weahome.cn/article/psicgo.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部