限定符

含義

字元 說明
* 零次或多次匹配前面的字元或子表達式。例如,zo* 匹配 z 和 zoo。* 等效於 {0,}。
+ 一次或多次匹配前面的字元或子表達式。例如,zo+ 匹配 zo 和 zoo,但不匹配 z。+ 等效於 {1,}。
? 零次或一次匹配前面的字元或子表達式。例如,do(es)? 匹配 do 或 does 中的 do。? 等效於 {0,1}。
{n} n 是非負整數。正好匹配 n次。例如,o{2} 不匹配 Bob 中的 o,但匹配 food 中的兩個 o。
{n,} n 是非負整數。至少匹配 n 次。例如,o{2,} 不匹配 Bob 中的 o,而匹配 foooood 中的所有 o。o{1,} 等效於 o+。o{0,} 等效於 o*。
{n,m} m和 n是非負整數,其中 n<= m。匹配至少 n次,至多 m次。例如,o{1,3} 匹配 fooooood 中的頭三個 o。o{0,1} 等效於 o?。注意:您不能將空格插入逗號和數字之間。

詳解

由於章節編號在大的輸入文檔中會很可能超過九,所以您需要一種方式來處理兩位或三位章節編號。限定符給您這種能力。下面的正則表達式匹配編號為任何位數的章節標題:
/Chapter &#91;1-9&#93;&#91;0-9&#93;*/請注意,限定符出現在範圍表達式之後。因此,它套用於整個範圍表達式,在本例中,只指定從 0 到 9 的數字(包括 0 和 9)。
這裡不使用 + 限定符,因為在第二個位置或後面的位置不一定需要有一個數字。也不使用?字元,因為它將章節編號限制到只有兩位數。您需要至少匹配 Chapter 和空格字元後面的一個數字。
如果您知道章節編號被限制為只有 99 章,可以使用下面的表達式來至少指定一位但至多兩位數字。
/Chapter &#91;0-9&#93;{1,2}/上面的表達式的缺點是,大於 99 的章節編號仍只匹配開頭兩位數字。另一個缺點是 Chapter 0 也將匹配。只匹配兩位數字的更好的表達式如下:
/Chapter &#91;1-9&#93;&#91;0-9&#93;?/或
/Chapter &#91;1-9&#93;&#91;0-9&#93;{0,1}/*、+ 和 ? 限定符都被稱為“貪心的”,因為它們匹配儘可能多的文本。但是,有時您只需要最小的匹配。
例如,您可能搜尋 HTML 文檔,以查找括在 H1 標記內的章節標題。該文本在您的文檔中如下:
<H1>Chapter 1 – Introduction to Regular Expressions</H1>下面的表達式匹配從開始小於符號 (<) 到關閉 H1 標記的大於符號 (>) 之間的所有內容。
/<.*>/如果您只需要匹配開始 H1 標記,下面的“非貪心”表達式只匹配 <H1>。
/<.*?>/通過在 *、+ 或 ? 限定符之後放置 ?,該表達式從“貪心”表達式轉換為“非貪心”表達式或者最小匹配。

相關詞條

相關搜尋

熱門詞條

聯絡我們