到現(xiàn)在為止,所看到的示例都只考慮查找任何地方出現(xiàn)的章節(jié)標(biāo)題。出現(xiàn)的任何一個字符串 'Chapter' 后跟一個空格和一個數(shù)字可能是一個真正的章節(jié)標(biāo)題,也可能是對其他章節(jié)的交叉引用。由于真正的章節(jié)標(biāo)題總是出現(xiàn)在一行的開始,因此需要設(shè)計一個方法只查找標(biāo)題而不查找交叉引用。
定位符提供了這個功能。定位符可以將一個正則表達(dá)式固定在一行的開始或結(jié)束。也可以創(chuàng)建只在單詞內(nèi)或只在單詞的開始或結(jié)尾處出現(xiàn)的正則表達(dá)式。下表包含了正則表達(dá)式及其含義的列表:
| 字符 | 描述 |
|---|---|
| ^ | 匹配輸入字符串的開始位置。如果設(shè)置了 RegExp 對象的 Multiline 屬性,^ 也匹配 '/n' 或 '/r' 之后的位置。 |
| $ | 匹配輸入字符串的結(jié)束位置。如果設(shè)置了RegExp 對象的 Multiline 屬性,$ 也匹配 '/n' 或 '/r' 之前的位置。 |
| /b | 匹配一個單詞邊界,也就是指單詞和空格間的位置。 |
| /B | 匹配非單詞邊界。 |
不能對定位符使用限定符。因為在一個換行符或者單詞邊界的前面或后面不會有連續(xù)多個位置,因此諸如 '^*' 的表達(dá)式是不允許的。
要匹配一行文字開始位置的文字,請在正則表達(dá)式的開始處使用 '^' 字符。不要把 '^' 的這個語法與其在括號表達(dá)式中的語法弄混。它們的語法根本不同。
要匹配一行文字結(jié)束位置的文字,請在正則表達(dá)式的結(jié)束處使用 '$' 字符。
要在查找章節(jié)標(biāo)題時使用定位符,下面的 Visual Basic Scripting Edition 正則表達(dá)式將匹配位于一行的開始處最多有兩個數(shù)字的章節(jié)標(biāo)題:
/^Chapter [1-9][0-9]{0,1}/VBScript 中相同功能的正則表達(dá)式如下:
"^Chapter [1-9][0-9]{0,1}"一個真正的章節(jié)標(biāo)題不僅出現(xiàn)在一行的開始,而且這一行中也僅有這一個內(nèi)容,因此,它必然也位于一行的結(jié)束。下面的表達(dá)式確保所指定的匹配只匹配章節(jié)而不會匹配交叉引用。它是通過創(chuàng)建一個只匹配一行文字的開始和結(jié)束位置的正則表達(dá)式來實現(xiàn)的。
/^Chapter [1-9][0-9]{0,1}$/對 VBScript 則使用:
"^Chapter [1-9][0-9]{0,1}$"匹配單詞邊界有少許不同,但卻給正則表達(dá)式增加了一個非常重要的功能。單詞邊界就是單詞和空格之間的位置。非單詞邊界就是其他任何位置。下面的 Visual Basic Scripting Edition 表達(dá)式將匹配單詞 'Chapter' 的前三個字符,因為它們出現(xiàn)在單詞邊界后:
新聞熱點
疑難解答
圖片精選