Java正则表达式中的反向引用
生活随笔
收集整理的這篇文章主要介紹了
Java正则表达式中的反向引用
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
Java正則表達式中的反向引用是Java提供的另一個重要功能。 要了解反向引用 ,我們首先需要了解群組 。 正則表達式中的分組意味著將多個字符視為一個單元。 通過將要分組的字符放在一組括號“()”中來創建它們。 每組括號對應一個組 。
反向引用很方便,因為它允許我們重復模式而無需再次編寫。 我們可以使用\#來引用先前定義的組(#是組號)。 閱讀以下兩個示例后,這將更有意義。
示例1:查找重復圖案
(\ d \ d \ d)\ 1匹配123123,但不連續匹配123456。 這表明所引用的模式必須確切地是名稱。
String str = "123456"; Pattern p = Pattern.compile("(\\d\\d\\d)\\1"); Matcher m = p.matcher(str); System.out.println(m.groupCount()); while (m.find()) {String word = m.group();System.out.println(word + " " + m.start() + " " + m.end()); }1 123123 0 6示例2:查找重復的單詞
String pattern = "\\b(\\w+)\\b[\\w\\W]*\\b\\1\\b"; Pattern p = Pattern.compile(pattern, Pattern.CASE_INSENSITIVE); String phrase = "unique is not duplicate but unique, Duplicate is duplicate."; Matcher m = p.matcher(phrase); while (m.find()) {String val = m.group();System.out.println("Matching subsequence is \"" + val + "\"");System.out.println("Duplicate word: " + m.group(1) + "\n"); }Matching subsequence is “unique is not duplicate but unique” Duplicate word: uniqueMatching subsequence is “Duplicate is duplicate” Duplicate word: Duplicate注意:這不是使用正則表達式查找重復單詞的好方法。 從上面的示例中,第一個“重復項”不匹配。
為什么要使用反向引用?
- 查看更多正則表達式示例 。
翻譯自: https://www.javacodegeeks.com/2013/09/backreferences-in-java-regular-expressions.html
總結
以上是生活随笔為你收集整理的Java正则表达式中的反向引用的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: DDOS攻击的整体特点(DDOS攻击小组
- 下一篇: 旅行报告:JavaOne 2013 –重