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