學(xué)習(xí)正則表達(dá)式的最好方法是從例子開始,理解例子之后再自己對例子進(jìn)行修改,實驗。下面給出了不少簡單的例子,并對它們作了詳細(xì)的說明。
假設(shè)你在一篇英文小說里查找 hi,你可以使用正則表達(dá)式 hi。
這幾乎是最簡單的正則表達(dá)式了,它可以精確匹配這樣的字符串:由兩個字符組成,前一個字符是h,后一個是 i。通常,處理正則表達(dá)式的工具會提供一個忽略大小寫的選項,如果選中了這個選項,它可以匹配 hi,HI,Hi,hI 這四種情況中的任意一種。
不幸的是,很多單詞里包含 hi 這兩個連續(xù)的字符,比如 him,history,high 等等。用 hi 來查找的話,這里邊的hi也會被找出來。如果要精確地查找 hi 這個單詞的話,我們應(yīng)該使用 \bhi\b。
\b 是正則表達(dá)式規(guī)定的一個特殊代碼(好吧,某些人叫它元字符,metacharacter),代表著單詞的開頭或結(jié)尾,也就是單詞的分界處。雖然通常英文的單詞是由空格,標(biāo)點符號或者換行來分隔的,但是 \b 并不匹配這些單詞分隔字符中的任何一個,它只匹配一個位置。
假如你要找的是 hi 后面不遠(yuǎn)處跟著一個 Lucy,你應(yīng)該用 \bhi\b.*\bLucy\b。
這里,.
是另一個元字符,匹配除了換行符以外的任意字符。*
同樣是元字符,不過它代表的不是字符,也不是位置,而是數(shù)量——它指定*
前邊的內(nèi)容可以連續(xù)重復(fù)使用任意次以使整個表達(dá)式得到匹配。因此,.*
連在一起就意味著任意數(shù)量的不包含換行的字符?,F(xiàn)在 \bhi\b.*\bLucy\b 的意思就很明顯了:先是一個單詞 hi,然后是任意個任意字符(但不能是換行),最后是 Lucy 這個單詞。
如果需要更精確的說法,\b 匹配這樣的位置:它的前一個字符和后一個字符不全是(一個是,一個不是或不存在)\w。
如果同時使用其它元字符,我們就能構(gòu)造出功能更強大的正則表達(dá)式。比如下面這個例子:
0\d\d-\d\d\d\d\d\d\d\d 匹配這樣的字符串:以 0 開頭,然后是兩個數(shù)字,然后是一個連字號“-”,最后是 8 個數(shù)字(也就是中國的電話號碼。當(dāng)然,這個例子只能匹配區(qū)號為 3 位的情形)。
換行符就是'\n',ASCII 編碼為 10(十六進(jìn)制 0x0A)的字符。
這里的\d 是個新的元字符,匹配一位數(shù)字(0,或 1,或 2,或……)。-不是元字符,只匹配它本身——連字符(或者減號,或者中橫線,或者隨你怎么稱呼它)。
為了避免那么多煩人的重復(fù),我們也可以這樣寫這個表達(dá)式:0\d{2}-\d{8}。這里\d 后面的{2}({8})的意思是前面\d 必須連續(xù)重復(fù)匹配 2 次(8 次)。
更多建議: