中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java正則表達式API邊界匹配怎么實現

發布時間:2022-06-10 09:22:09 來源:億速云 閱讀:171 作者:iii 欄目:開發技術

本篇內容主要講解“Java正則表達式API邊界匹配怎么實現”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Java正則表達式API邊界匹配怎么實現”吧!

Boundary Matchers

Java regex API還支持邊界匹配。如果我們關心在輸入文本中匹配的確切位置,那么這就是我們要尋找的。在前面的示例中,我們關心的只是是否找到匹配項。

為了僅在文本開頭所需的正則表達式為true時匹配,我們使用插入符號^。

此測試將失敗,因為可以在開頭找到文本dog:

@Test
public void givenText_whenMatchesAtBeginning_thenCorrect() {
    int matches = runTest("^dog", "dogs are friendly");
 
    assertTrue(matches > 0);
}

下面的測試將失敗:

@Test
public void givenTextAndWrongInput_whenMatchFailsAtBeginning_
  thenCorrect() {
    int matches = runTest("^dog", "are dogs are friendly?");
 
    assertFalse(matches > 0);
}

為了僅在文本末尾所需的正則表達式為true時匹配,我們使用美元字符$。在以下情況下會找到匹配項:

@Test
public void givenText_whenMatchesAtEnd_thenCorrect() {
    int matches = runTest("dog$", "Man's best friend is a dog");
 
    assertTrue(matches > 0);
}

并且沒有找到匹配:

@Test
public void givenTextAndWrongInput_whenMatchFailsAtEnd_thenCorrect() {
    int matches = runTest("dog$", "is a dog man's best friend?");
 
    assertFalse(matches > 0);
}

如果僅在單詞邊界處找到所需文本時才需要匹配,則在正則表達式的開頭和結尾使用\\b正則表達式:

空格是單詞邊界:

@Test
public void givenText_whenMatchesAtWordBoundary_thenCorrect() {
    int matches = runTest("\\bdog\\b", "a dog is friendly");
 
    assertTrue(matches > 0);
}

行首的空字符串也是單詞邊界:

@Test
public void givenText_whenMatchesAtWordBoundary_thenCorrect2() {
    int matches = runTest("\\bdog\\b", "dog is man's best friend");
 
    assertTrue(matches > 0);
}

這些測試之所以通過,是因為字符串的開頭以及文本之間的空格標記了單詞邊界,但是以下測試顯示了相反的結果:

@Test
public void givenWrongText_whenMatchFailsAtWordBoundary_thenCorrect() {
    int matches = runTest("\\bdog\\b", "snoop dogg is a rapper");
 
    assertFalse(matches > 0);
}

一行中出現的兩個單詞字符不會標記單詞邊界,但我們可以通過更改正則表達式的結尾來查找非單詞邊界:

@Test
public void givenText_whenMatchesAtWordAndNonBoundary_thenCorrect() {
    int matches = runTest("\\bdog\\B", "snoop dogg is a rapper");
    assertTrue(matches > 0);
}

Pattern Class Methods

之前,我們只以基本方式創建了模式對象。然而,這個類有另一個compile方法的變體,它接受一組標志以及影響模式匹配方式的regex參數。

這些標志只是抽象的整數值。讓我們重載test類中的runTest方法,以便它可以將標志作為第三個參數:

public static int runTest(String regex, String text, int flags) {
    pattern = Pattern.compile(regex, flags);
    matcher = pattern.matcher(text);
    int matches = 0;
    while (matcher.find()){
        matches++;
    }
    return matches;
}

在本節中,我們將了解不同的支持標志以及它們的使用方式。

Pattern.CANON_EQ

此標志啟用canonical equivalence,當且僅當兩個字符的完整規范分解匹配時,才會認為這兩個字符匹配。

考慮帶重音的Unicode字符é。它的復合代碼點是u00E9。但是,Unicode的組成字符eu0065u0301也有單獨的代碼點。在這種情況下,合成字符u00E9與雙字符序列u0065 u0301無法區分。

默認情況下,匹配不考慮規范等效:

@Test
public void givenRegexWithoutCanonEq_whenMatchFailsOnEquivalentUnicode_thenCorrect() {
    int matches = runTest("\u00E9", "\u0065\u0301");
 
    assertFalse(matches > 0);
}

但如果添加標志,則測試將通過:

@Test
public void givenRegexWithCanonEq_whenMatchesOnEquivalentUnicode_thenCorrect() {
    int matches = runTest("\u00E9", "\u0065\u0301", Pattern.CANON_EQ);
 
    assertTrue(matches > 0);
}

Pattern.CASE_INSENSITIVE

無論大小寫,此標志都支持匹配。默認情況下,匹配會考慮大小寫:

@Test
public void givenRegexWithDefaultMatcher_whenMatchFailsOnDifferentCases_thenCorrect() {
    int matches = runTest("dog", "This is a Dog");
 
    assertFalse(matches > 0);
}

因此,使用此標志,我們可以更改默認行為:

@Test
public void givenRegexWithCaseInsensitiveMatcher
  _whenMatchesOnDifferentCases_thenCorrect() {
    int matches = runTest(
      "dog", "This is a Dog", Pattern.CASE_INSENSITIVE);
 
    assertTrue(matches > 0);
}

我們還可以使用等效的嵌入標志表達式來實現相同的結果:

@Test
public void givenRegexWithEmbeddedCaseInsensitiveMatcher
  _whenMatchesOnDifferentCases_thenCorrect() {
    int matches = runTest("(?i)dog", "This is a Dog");
 
    assertTrue(matches > 0);
}

Pattern.COMMENTS

Java API允許在正則表達式中包含使用#的注釋。這有助于記錄復雜的正則表達式,而其他程序員可能無法立即看到這些正則表達式。

comments標志使matcher忽略正則表達式中的任何空白或注釋,只考慮模式。

在默認匹配模式下,以下測試將失敗:

@Test
public void givenRegexWithComments_whenMatchFailsWithoutFlag_thenCorrect() {
    int matches = runTest(
      "dog$  #check for word dog at end of text", "This is a dog");
 
    assertFalse(matches > 0);
}

這是因為匹配器將在輸入文本中查找整個正則表達式,包括空格和#字符。但當我們使用該標志時,它將忽略額外的空格,并且以#開頭的每個文本都將被視為每行要忽略的注釋:

@Test
public void givenRegexWithComments_whenMatchesWithFlag_thenCorrect() {
    int matches = runTest(
      "dog$  #check end of text","This is a dog", Pattern.COMMENTS);
 
    assertTrue(matches > 0);
}

還有一個替代的嵌入式標志表達式:

@Test
public void givenRegexWithComments_whenMatchesWithEmbeddedFlag_thenCorrect() {
    int matches = runTest(
      "(?x)dog$  #check end of text", "This is a dog");
 
    assertTrue(matches > 0);
}

到此,相信大家對“Java正則表達式API邊界匹配怎么實現”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

孟村| 眉山市| 溧阳市| 渝中区| 文水县| 双牌县| 荔浦县| 仁化县| 竹溪县| 兴城市| 澜沧| 万山特区| 伽师县| 崇阳县| 四子王旗| 韶山市| 河东区| 从化市| 辛集市| 汝南县| 西乡县| 沁水县| 大冶市| 辰溪县| 益阳市| 开阳县| 游戏| 广河县| 正定县| 望都县| 澜沧| 五指山市| 芷江| 商洛市| 巨野县| 襄城县| 滦平县| 江川县| 上杭县| 清苑县| 全州县|