如果您不能指定構(gòu)成匹配的字符的數(shù)量,那么正則表達(dá)式支持限定符的概念。這些限定符使您能夠指定,為使匹配為真,正則表達(dá)式的某個(gè)給定組件必須出現(xiàn)多少次。
下表說(shuō)明各種限定符以及它們的含義:
字符 說(shuō)明
* 零次或多次匹配前面的字符或子表達(dá)式。例如,zo* 匹配 z 和 zoo。* 等效于 {0,}。
+ 一次或多次匹配前面的字符或子表達(dá)式。例如,zo+ 匹配 zo 和 zoo,但不匹配 z。+ 等效于 {1,}。
? 零次或一次匹配前面的字符或子表達(dá)式。例如,do(es)? 匹配 do 或 does 中的 do。? 等效于 {0,1}。
{n} n 是非負(fù)整數(shù)。正好匹配 n 次。例如,o{2} 不匹配 Bob 中的 o,但匹配 food 中的兩個(gè) o。
{n,} n 是非負(fù)整數(shù)。至少匹配 n 次。例如,o{2,} 不匹配 Bob 中的 o,而匹配 foooood 中的所有 o。o{1,} 等效于 o+。o{0,} 等效于 o*。
{n,m} m 和 n 是非負(fù)整數(shù),其中 n <= m。至少匹配 n 次,至多匹配 m 次。例如,o{1,3} 匹配 fooooood 中的頭三個(gè) o。o{0,1} 等效于 o?。注意:您不能將空格插入逗號(hào)和數(shù)字之間。
由于章節(jié)編號(hào)在大的輸入文檔中會(huì)很可能超過九,所以您需要一種方式來(lái)處理兩位或三位章節(jié)編號(hào)。限定符給您這種能力。下面的正則表達(dá)式匹配編號(hào)為任何位數(shù)的章節(jié)標(biāo)題:
/Chapter [1-9][0-9]*/
請(qǐng)注意,限定符出現(xiàn)在范圍表達(dá)式之后。因此,它應(yīng)用于整個(gè)范圍表達(dá)式,在本例中,只指定從 0 到 9 的數(shù)字(包括 0 和 9)。
這里不使用 + 限定符,因?yàn)樵诘诙€(gè)位置或后面的位置不一定需要有一個(gè)數(shù)字。也不使用?字符,因?yàn)樗鼘⒄鹿?jié)編號(hào)限制到只有兩位數(shù)。您需要至少匹配 Chapter 和空格字符后面的一個(gè)數(shù)字。
如果您知道章節(jié)編號(hào)被限制為只有 99 章,可以使用下面的表達(dá)式來(lái)至少指定一位但至多兩位數(shù)字。
/Chapter [0-9]{1,2}/
上面的表達(dá)式的缺點(diǎn)是,大于 99 的章節(jié)編號(hào)仍只匹配開頭兩位數(shù)字。另一個(gè)缺點(diǎn)是 Chapter 0 也將匹配。只匹配兩位數(shù)字的更好的表達(dá)式如下:
/Chapter [1-9][0-9]?/
或
/Chapter [1-9][0-9]{0,1}/
*、+ 和 ? 限定符都被稱為“貪心的”,因?yàn)樗鼈兤ヅ浔M可能多的文本。但是,有時(shí)您只需要最小的匹配。
例如,您可能搜索 HTML 文檔,以查找括在 H1 標(biāo)記內(nèi)的章節(jié)標(biāo)題。該文本在您的文檔中如下:
<H1>Chapter 1 – Introduction to Regular Expressions</H1>
下面的表達(dá)式匹配從開始小于符號(hào) (<) 到關(guān)閉 H1 標(biāo)記的大于符號(hào) (>) 之間的所有內(nèi)容。
/<.*>/
如果您只需要匹配開始 H1 標(biāo)記,下面的“非貪心”表達(dá)式只匹配 <H1>。
/<.*?>/
通過在 *、+ 或 ? 限定符之后放置 ?,該表達(dá)式從“貪心”表達(dá)式轉(zhuǎn)換為“非貪心”表達(dá)式或者最小匹配。
更多信息請(qǐng)查看IT技術(shù)專欄