濮阳杆衣贸易有限公司

主頁 > 知識庫 > Java正則表達式提取字符的方法實例

Java正則表達式提取字符的方法實例

熱門標簽:鄂州人工智能電銷機器人軟件 地圖標注字母的軟件 實用地圖標注app 線上教育ai外呼系統(tǒng) 400免費電話去哪申請 地圖標注商戶中心要收錢多少 宿遷智能外呼系統(tǒng)供應商 css百度地圖標注位置顯示 菏澤智能ai電銷機器人銷售公司

正好遇到一個需求需要將字符串中特定的字符全部提取出來,這個如果是按常規(guī)的字符串處理的話非常的繁瑣。于是想到用正則表達式來完成。項目需求是這樣的:需要提取車牌號中最后一個數字,比如說:蘇A7865提取5,蘇A876X提取6

實現方法:

import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class Test {
public static void main(String[] args) {
String s = "A876X";
// 把要匹配的字符串寫成正則表達式,然后要提取的字符使用括號括起來
// 在這里,我們要提取最后一個數字,正則規(guī)則就是“一個數字加上大于等于0個非數字再加上結束符”
Pattern pattern = Pattern.compile("(\\d)[^\\d]*$");
Matcher matcher = pattern.matcher(s);
if(matcher.find())
System.out.println(matcher.group(1));
}
}

關于Matcher 中的幾個方法說明:

Mathcer.start()/ Matcher.end()/ Matcher.group()
當使用matches(),lookingAt(),find()執(zhí)行匹配操作后,就可以利用以上三個方法得到更詳細的信息.
start()返回匹配到的子字符串在字符串中的索引位置.
end()返回匹配到的子字符串的最后一個字符在字符串中的索引位置.
group()返回匹配到的子字符串

Java代碼示例:

Pattern p=Pattern.compile(“\d+”); 
Matcher m=p.matcher(“aaa2223bb”); 
m.find();//匹配2223 
m.start();//返回3 
m.end();//返回7,返回的是2223后的索引號 
m.group();//返回2223
Mathcer m2=p.matcher(“2223bb”); 
m2.lookingAt(); //匹配2223 
m2.start(); //返回0,由于lookingAt()只能匹配前面的字符串,所以當使用lookingAt()匹配時,start()方法總是返回0 
m2.end(); //返回4 
m2.group(); //返回2223
Matcher m3=p.matcher(“2223”); //如果Matcher m3=p.matcher(“2223bb”); 那么下面的方法出錯,因為不匹配返回false 
m3.matches(); //匹配整個字符串 
m3.start(); //返回0 
m3.end(); //返回3,原因相信大家也清楚了,因為matches()需要匹配所有字符串 
m3.group(); //返回2223

說了這么多,相信大家都明白了以上幾個方法的使用,該說說正則表達式的分組在java中是怎么使用的.
start(),end(),group()均有一個重載方法它們是start(int i),end(int i),group(int i)專用于分組操作,Mathcer類還有一個groupCount()用于返回有多少組.

Java代碼示例:

Pattern p=Pattern.compile(“([a-z]+)(\d+)”); 
Matcher m=p.matcher(“aaa2223bb”); 
m.find(); //匹配aaa2223 
m.groupCount(); //返回2,因為有2組 
m.start(1); //返回0 返回第一組匹配到的子字符串在字符串中的索引號 
m.start(2); //返回3 
m.end(1); //返回3 返回第一組匹配到的子字符串的最后一個字符在字符串中的索引位置. 
m.end(2); //返回7 
m.group(1); //返回aaa,返回第一組匹配到的子字符串 
m.group(2); //返回2223,返回第二組匹配到的子字符串

現在我們使用一下稍微高級點的正則匹配操作,例如有一段文本,里面有很多數字,而且這些數字是分開的,我們現在要將文本中所有數字都取出來,利用java的正則操作是那么的簡單.

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

現在大家應該知道,每次執(zhí)行匹配操作后start(),end(),group()三個方法的值都會改變,改變成匹配到的子字符串的信息,以及它們的重載方法,也會改變成相應的信息.

注意:只有當匹配操作成功,才可以使用start(),end(),group()三個方法,否則會拋出java.lang.IllegalStateException,也就是當matches(),lookingAt(),find()其中任意一個方法返回true時,才可以使用。

以上內容給介紹了Java正則表達式提取字符的方法實例,希望對大家有所幫助。

您可能感興趣的文章:
  • Java 正則表達式詳解
  • JAVA正則表達式 Pattern和Matcher
  • java中 利用正則表達式提取( )內內容
  • Java 正則表達式學習總結和一些小例子
  • java正則表達式四種常用的處理方式(匹配、分割、替代、獲?。?/li>
  • JAVA中正則表達式匹配,替換,查找,切割的方法
  • Java正則表達式過濾出字母、數字和中文
  • java正則表達式驗證郵箱、電話號碼示例
  • java正則表達式提取數字的方法實例
  • JAVA正則表達式的基本使用教程

標簽:鞍山 三亞 綿陽 六安 恩施 咸陽 梅州 池州

巨人網絡通訊聲明:本文標題《Java正則表達式提取字符的方法實例》,本文關鍵詞  Java,正則,表達式,提取,字符,;如發(fā)現本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Java正則表達式提取字符的方法實例》相關的同類信息!
  • 本頁收集關于Java正則表達式提取字符的方法實例的相關信息資訊供網民參考!
  • 推薦文章
    全州县| 班玛县| 嘉荫县| 邳州市| 东海县| 信丰县| 旅游| 永济市| 樟树市| 西乌珠穆沁旗| 方城县| 辉南县| 余干县| 高邑县| 邵武市| 咸丰县| 永修县| 盱眙县| 庐江县| 龙川县| 秦皇岛市| 祁阳县| 东兰县| 洪江市| 九江县| 内乡县| 株洲县| 金门县| 石家庄市| 高平市| 顺平县| 佳木斯市| 伊金霍洛旗| 双辽市| 澄江县| 启东市| 鲁甸县| 博湖县| 伊春市| 上杭县| 崇州市|