2 正則表達式中的常用模式
下面是正則表達式中的一些常用模式。
| /pattern/ |
結果 |
| . |
匹配除換行符以外的所有字符 |
| x? |
匹配 0 次或一次 x 字符串 |
| x* |
匹配 0 次或多次 x 字符串,但匹配可能的最少次數(shù) |
| x+ |
匹配 1 次或多次 x 字符串,但匹配可能的最少次數(shù) |
| .* |
匹配 0 次或一次的任何字符 |
| .+ |
匹配 1 次或多次的任何字符 |
| {m} |
匹配剛好是 m 個 的指定字符串 |
| {m,n} |
匹配在 m個 以上 n個 以下 的指定字符串 |
| {m,} |
匹配 m個 以上 的指定字符串 |
| [] |
匹配符合 [] 內的字符 |
| [^] |
匹配不符合 [] 內的字符 |
| [0-9] |
匹配所有數(shù)字字符 |
| [a-z] |
匹配所有小寫字母字符 |
| [^0-9] |
匹配所有非數(shù)字字符 |
| [^a-z] |
匹配所有非小寫字母字符 |
| ^ |
匹配字符開頭的字符 |
| $ |
匹配字符結尾的字符 |
| \d |
匹配一個數(shù)字的字符,和 [0-9] 語法一樣 |
| \d+ |
匹配多個數(shù)字字符串,和 [0-9]+ 語法一樣 |
| \D |
非數(shù)字,其他同 \d |
| \D+ |
非數(shù)字,其他同 \d+ |
| \w |
英文字母或數(shù)字的字符串,和 [a-zA-Z0-9] 語法一樣 |
| \w+ |
和 [a-zA-Z0-9]+ 語法一樣 |
| \W |
非英文字母或數(shù)字的字符串,和 [^a-zA-Z0-9] 語法一樣 |
| \W+ |
和 [^a-zA-Z0-9]+ 語法一樣 |
| \s |
空格,和 [\n\t\r\f] 語法一樣 |
| \s+ |
和 [\n\t\r\f]+ 一樣 |
| \S |
非空格,和 [^\n\t\r\f] 語法一樣 |
| \S+ |
和 [^\n\t\r\f]+ 語法一樣 |
| \b |
匹配以英文字母,數(shù)字為邊界的字符串 |
| \B |
匹配不以英文字母,數(shù)值為邊界的字符串 |
| a|b|c |
匹配符合a字符 或是b字符 或是c字符 的字符串 |
| abc |
匹配含有 abc 的字符串 |
| (pattern) |
() 這個符號會記住所找尋到的字符串,是一個很實用的語法。第一個 () 內所找到的字符串變成 $1 這個變量或是 \1 變量,第二個 () 內所找到的字符串變成 $2 這個變量或是 \2 變量,以此類推下去。 |
| /pattern/i |
i 這個參數(shù)表示忽略英文大小寫,也就是在匹配字符串的時候,不考慮英文的大小寫問題。 |
| \ |
如果要在 pattern 模式中找尋一個特殊字符,如 "*",則要在這個字符前加上 \ 符號,這樣才會讓特殊字符失效 |
|
下面給出一些例子:
| 范例 |
說明 |
| /perl/ |
找到含有 perl 的字符串 |
| /^perl/ |
找到開頭是 perl 的字符串 |
| /perl$/ |
找到結尾是 perl 的字符串 |
| /c|g|i/ |
找到含有 c 或 g 或 i 的字符串 |
| /cg{2,4}i/ |
找到 c 后面跟著 2個到 4個 g ,再跟著 i 的字符串 |
| /cg{2,}i/ |
找到 c 后面跟著 2個以上 g ,再跟著 i 的字符串 |
| /cg{2}i/ |
找到 c 后面跟著 2個 g,再跟著 i 的字符串 |
| /cg*i/ |
找到 c 后面跟著 0個或多個 g ,再跟著 i 的字符串,如同/cg{0,1}i/ |
| /cg+i/ |
找到 c 后面跟著一個以上 g,再跟著 i 的字符串,如同/cg{1,}i/ |
| /cg?i/ |
找到 c 后面跟著 0個或是 1個 g ,再跟著 i 的字符串,如同/cg{0,1}i/ |
| /c.i/ |
找到 c 后面跟著一個任意字符,再跟著 i 的字符串 |
| /c..i/ |
找到 c 后面跟著二個任意字符,再跟著 i 的字符串 |
| /[cgi]/ |
找到符合有這三個字符任意一個的字符串 |
| /[^cgi]/ |
找到?jīng)]有這三個字符中任意一個的字符串 |
| /\d/ |
找尋符合數(shù)字的字符,可以使用/\d+/來表示一個或是多個數(shù)字組成的字符串 |
| /\D/ |
找尋符合不是數(shù)字的字符,可以使用/\D+/來表示一個或是更多個非數(shù)字組成的字符串 |
| /\*/ |
找尋符合 * 這個字符,因為 * 在常規(guī)表達式中有它的特殊意思,所以要在這個特殊符號前加上 \ 符號,這樣才會讓這個特殊字符失效 |
| /abc/i |
找尋符合 abc 的字符串而且不考慮這些字符串的大小寫 |
3 正則表達式的八大原則
如果在 Unix 中曾經(jīng)使用過 sed、awk、grep 這些命令的話,相信對于 Perl 語言中的正則表達式(Regular Expression)不會感到陌生。Perl 語言由于有這個功能,所以對字符串的處理能力非常強。在Perl語言的程序中,經(jīng)??梢钥吹秸齽t表達式的運用,在 CGI 程序設計中也不例外。
正則表達式是初學 Perl 的難點所在,不過只要一旦掌握其語法,你就可以擁有幾乎無限的模式匹配能力,而且 Perl 編程的大部分工作都是掌握常規(guī)表達式。下面給大家介紹幾條正則表達式使用過程中的 8 大原則。
正則表達式在對付數(shù)據(jù)的戰(zhàn)斗中可形成龐大的聯(lián)盟——這常常是一場戰(zhàn)爭。我們要記住下面八條原則:
· 原則1:正則表達式有三種不同形式(匹配(m/ /),替換(s/ / /eg)和轉換(tr/ / /))。
· 原則2:正則表達式僅對標量進行匹配( $scalar =~ m/a/; 可以工作; @array =~ m/a/ 將把@array作為標量對待,因此可能不會成功)。
· 原則3:正則表達式匹配一個給定模式的最早的可能匹配。缺省時,僅匹配或替換正則表達式一次( $a = ‘string string2‘; $a =~ s/string/ /; 導致 $a = ‘string 2‘)。
· 原則4:正則表達式能夠處理雙引號所能處理的任意和全部字符( $a =~ m/$varb/ 在匹配前把varb擴展為變量;如果 $varb = ‘a(chǎn)‘ $a = ‘a(chǎn)s‘,$a =~ s/$varb/ /; 等價于 $a =~ s/a/ /; ,執(zhí)行結果使 $a = " s" )。
· 原則5:正則表達式在求值過程中產(chǎn)生兩種情況:結果狀態(tài)和反向引用: $a=~ m/pattern/ 表示 $a 中是否有子串 pattern 出現(xiàn),$a =~ s/(word1)(word2)/$2$1/ 則“調換”這兩個單詞。
· 原則6:正則表達式的核心能力在于通配符和多重匹配運算符以及它們如何操作。$a =~ m/\w+/ 匹配一個或多個單詞字符;$a =~ m/\d/" 匹配零個或多個數(shù)字。
· 原則7:如果欲匹配不止一個字符集合,Perl使用 "|" 來增加靈活性。如果輸入 m/(cat|dog)/ 則相當于“匹配字符串 cat 或者 dog。
· 原則8:Perl用 (?..) 語法給正則表達式提供擴展功能。(這一點請同學們課后看相關資料)
想要學習所有這些原則?我建議大家先從簡單的開始,并且不斷的嘗試和實驗。實際上如果學會了 $a =~ m/ERROR/ 是在 $a 中查找子串ERROR,那么你就已經(jīng)比在 C 這樣的低層語言中得到了更大的處理能力。