本文目錄一覽:
- 1、JAVA正則表達式,matcher.find和 matcher.matches的區別
- 2、java matcher方法
- 3、java 正則表達式中matcher類起什麼作用
- 4、Java中正則Matcher類的matches,lookAt和find的區別
- 5、Java中Matcher在while loop中的異常行為
- 6、JavaSE基礎中正則表達式Matcher類的獲取功能–group(),解惑必採納,謝謝
JAVA正則表達式,matcher.find和 matcher.matches的區別
1.find()方法是部分匹配,是查找輸入串中與模式匹配的子串,如果該匹配的串有組還可以使用group()函數。
matches()是全部匹配,是將整個輸入串與模式匹配,如果要驗證一個輸入的數據是否為數字類型或其他類型,一般要用matches()。
2.Pattern pattern= Pattern.compile(“.*?,(.*)”);
Matcher matcher = pattern.matcher(result);
if (matcher.find()) {
return matcher.group(1);
}
3.詳解:
matches
public static boolean matches(String regex, CharSequence input)
編譯給定正則表達式並嘗試將給定輸入與其匹配。
調用此便捷方法的形式
Pattern.matches(regex, input);
Pattern.compile(regex).matcher(input).matches() ;
如果要多次使用一種模式,編譯一次後重用此模式比每次都調用此方法效率更高。
參數:
regex – 要編譯的表達式
input – 要匹配的字元序列
拋出:
PatternSyntaxException – 如果表達式的語法無效
find
public boolean find()嘗試查找與該模式匹配的輸入序列的下一個子序列。
此方法從匹配器區域的開頭開始,如果該方法的前一次調用成功了並且從那時開始匹配器沒有被重置,則從以前匹配操作沒有匹配的第一個字元開始。
如果匹配成功,則可以通過 start、end 和 group 方法獲取更多信息。
matcher.start() 返回匹配到的子字元串在字元串中的索引位置.
matcher.end()返回匹配到的子字元串的最後一個字元在字元串中的索引位置.
matcher.group()返回匹配到的子字元串
返回:
當且僅當輸入序列的子序列匹配此匹配器的模式時才返回 true。
java matcher方法
看一下Pattern的matcher方法就知道了
/**
* Creates a matcher that will match the given input against this pattern.
* /p
*
* @param input
* The character sequence to be matched
*
* @return A new matcher for this pattern
*/
public Matcher matcher(CharSequence input) {
if (!compiled) {
synchronized(this) {
if (!compiled)
compile();
}
}
Matcher m = new Matcher(this, input);
return m;
}
它返回的是一個新的Matcher對象, 再執行它的matches()方法.
遇到不懂的時候看看源代碼就一目了然啦
java 正則表達式中matcher類起什麼作用
指定為字元串的Java正則表達式必須首先被編譯為pattern類的實例。然後,可將得到的模式用於創建 Matcher 對象,依照Java正則表達式,該對象可以與任意字元序列匹配。執行匹配所涉及的所有狀態都駐留在匹配器中,所以多個匹配器可以共享同一模式。
因此,典型的調用順序是
Pattern p = Pattern.compile(“a*b”);
Matcher m = p.matcher(“aaaaab”);
boolean b = m.matches();
Java中正則Matcher類的matches,lookAt和find的區別
matches匹配的是整個輸入序列,如果你了解整個輸入序列的結構,想從中查找各個部分或者校驗序列的合法性,則使用matches。
lookAt匹配的是輸入序列的開始,如果你只對輸入序列的開始部分感興趣,則使用lookAt。與matches的區別就是只要匹配到就結束,而不會匹配整個序列。
find是從輸入序列中查詢匹配到的串,如果你希望在輸入序列中尋找匹配的串,則使用find。
有一點要說明的是如果希望對不限定次數重複出現的串單獨進行處理,則必須使用find,matches和lookAt使用捕獲組也只能把這些串合併起來處理。
Java中Matcher在while loop中的異常行為
String loop = “a b c d e f g h i j k l”;
Matcher loopMatcher = Pattern.compile(“\\S+”).matcher(loop);
boolean loopEnded = false;
while (!loopEnded) {
use(matcher);
if (matcher.hitEnd()) {
loopEnded = true;
}
}
public static void use(Matcher matcher) {
if (!matcher.find()) {
System.out.println(“loop not ended but matcher hit end”);
}
}
運行後發現會輸出錯誤信息,循環到最後判斷一下就好了。
JavaSE基礎中正則表達式Matcher類的獲取功能–group(),解惑必採納,謝謝
在Java中,正則表達式是按照從左至右的順序對字元串進行掃描匹配的,首先,find()和group()都是Matcher類的函數,而不是String類的函數,所以find()和group()是對字元串從左至右掃描的函數,而不是對同一字元串反覆掃描的函數.
比如m.find()函數,如果找到匹配的子字元串,它返回true,沒有找到匹配的子字元串,它返回false.當寫到while條件中時,它表示持續在原字元串中從左至右掃描,當發現有匹配的子字元串時,由m.group()捕獲並輸出,如果掃描到原字元串尾也沒有發現匹配的子字元串,則返回false,跳出循環.
以你的程序為例,m.find()函數會在原字元串中持續從左至右掃描三個字元的以空格為邊界的單詞,直到字元串尾,而不會反覆從頭開始掃描原字元串,除非你在while循環中使用while(m.find(0)),m.find(0)表示從原字元串的第一個字元開始掃描匹配的子字元串,這樣程序會反覆從原字元串的第一個字元開始掃描匹配的子字元串,會陷入無限循環.
也就是說,find()和group()函數,只會對原字元串從左至右掃描一遍,這樣當第二次while循環時,不會是從原字元串頭重新開始,而是從上一次匹配的位置後面開始第二次搜尋.
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/279131.html