這篇文章主要介紹“Java正則表達(dá)式提取字符的方法”,在日常操作中,相信很多人在Java正則表達(dá)式提取字符的方法問(wèn)題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”Java正則表達(dá)式提取字符的方法”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!
員工經(jīng)過(guò)長(zhǎng)期磨合與沉淀,具備了協(xié)作精神,得以通過(guò)團(tuán)隊(duì)的力量開(kāi)發(fā)出優(yōu)質(zhì)的產(chǎn)品。創(chuàng)新互聯(lián)堅(jiān)持“專注、創(chuàng)新、易用”的產(chǎn)品理念,因?yàn)椤皩W⑺詫I(yè)、創(chuàng)新互聯(lián)網(wǎng)站所以易用所以簡(jiǎn)單”。公司專注于為企業(yè)提供成都網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè)、微信公眾號(hào)開(kāi)發(fā)、電商網(wǎng)站開(kāi)發(fā),微信小程序定制開(kāi)發(fā),軟件按需規(guī)劃網(wǎng)站等一站式互聯(lián)網(wǎng)企業(yè)服務(wù)。正好遇到一個(gè)需求需要將字符串中特定的字符全部提取出來(lái),這個(gè)如果是按常規(guī)的字符串處理的話非常的繁瑣。于是想到用正則表達(dá)式來(lái)完成。項(xiàng)目需求是這樣的:需要提取車牌號(hào)中最后一個(gè)數(shù)字,比如說(shuō):蘇A7865提取5,蘇A876X提取6
實(shí)現(xiàn)方法:
import java.util.regex.Matcher; import java.util.regex.Pattern; public class Test { public static void main(String[] args) { String s = "A876X"; // 把要匹配的字符串寫成正則表達(dá)式,然后要提取的字符使用括號(hào)括起來(lái) // 在這里,我們要提取最后一個(gè)數(shù)字,正則規(guī)則就是“一個(gè)數(shù)字加上大于等于0個(gè)非數(shù)字再加上結(jié)束符” Pattern pattern = Pattern.compile("(\\d)[^\\d]*$"); Matcher matcher = pattern.matcher(s); if(matcher.find()) System.out.println(matcher.group(1)); } }
關(guān)于Matcher 中的幾個(gè)方法說(shuō)明:
Mathcer.start()/ Matcher.end()/ Matcher.group()
當(dāng)使用matches(),lookingAt(),find()執(zhí)行匹配操作后,就可以利用以上三個(gè)方法得到更詳細(xì)的信息.
start()返回匹配到的子字符串在字符串中的索引位置.
end()返回匹配到的子字符串的最后一個(gè)字符在字符串中的索引位置.
group()返回匹配到的子字符串
Java代碼示例:
Pattern p=Pattern.compile(“\d+”); Matcher m=p.matcher(“aaa2223bb”); m.find();//匹配2223 m.start();//返回3 m.end();//返回7,返回的是2223后的索引號(hào) m.group();//返回2223 Mathcer m2=p.matcher(“2223bb”); m2.lookingAt(); //匹配2223 m2.start(); //返回0,由于lookingAt()只能匹配前面的字符串,所以當(dāng)使用lookingAt()匹配時(shí),start()方法總是返回0 m2.end(); //返回4 m2.group(); //返回2223 Matcher m3=p.matcher(“2223”); //如果Matcher m3=p.matcher(“2223bb”); 那么下面的方法出錯(cuò),因?yàn)椴黄ヅ浞祷豧alse m3.matches(); //匹配整個(gè)字符串 m3.start(); //返回0 m3.end(); //返回3,原因相信大家也清楚了,因?yàn)閙atches()需要匹配所有字符串 m3.group(); //返回2223
說(shuō)了這么多,相信大家都明白了以上幾個(gè)方法的使用,該說(shuō)說(shuō)正則表達(dá)式的分組在java中是怎么使用的.
start(),end(),group()均有一個(gè)重載方法它們是start(int i),end(int i),group(int i)專用于分組操作,Mathcer類還有一個(gè)groupCount()用于返回有多少組.
Java代碼示例:
Pattern p=Pattern.compile(“([a-z]+)(\d+)”); Matcher m=p.matcher(“aaa2223bb”); m.find(); //匹配aaa2223 m.groupCount(); //返回2,因?yàn)橛?組 m.start(1); //返回0 返回第一組匹配到的子字符串在字符串中的索引號(hào) m.start(2); //返回3 m.end(1); //返回3 返回第一組匹配到的子字符串的最后一個(gè)字符在字符串中的索引位置. m.end(2); //返回7 m.group(1); //返回aaa,返回第一組匹配到的子字符串 m.group(2); //返回2223,返回第二組匹配到的子字符串
現(xiàn)在我們使用一下稍微高級(jí)點(diǎn)的正則匹配操作,例如有一段文本,里面有很多數(shù)字,而且這些數(shù)字是分開(kāi)的,我們現(xiàn)在要將文本中所有數(shù)字都取出來(lái),利用java的正則操作是那么的簡(jiǎn)單.
Java代碼示例:
Pattern p=Pattern.compile(“\d+”); Matcher m=p.matcher(“我的QQ是:456456 我的電話是:0532214 我的郵箱是:aaa123@aaa.com”); while(m.find()) { System.out.println(m.group()); }
輸出:
456456
0532214
123
如將以上while()循環(huán)替換成
while(m.find()) { System.out.println(m.group()); System.out.print(“start:”+m.start()); System.out.println(” end:”+m.end()); }
則輸出:
456456
start:6 end:12
0532214
start:19 end:26
123
start:36 end:39
現(xiàn)在大家應(yīng)該知道,每次執(zhí)行匹配操作后start(),end(),group()三個(gè)方法的值都會(huì)改變,改變成匹配到的子字符串的信息,以及它們的重載方法,也會(huì)改變成相應(yīng)的信息.
注意:只有當(dāng)匹配操作成功,才可以使用start(),end(),group()三個(gè)方法,否則會(huì)拋出java.lang.IllegalStateException,也就是當(dāng)matches(),lookingAt(),find()其中任意一個(gè)方法返回true時(shí),才可以使用。
到此,關(guān)于“Java正則表達(dá)式提取字符的方法”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!