perl正則表達式

. 匹配除換行符以外的所有字符 

x? 匹配 0 次或一次 x 字符串 

x* 匹配 0 次或多次 x 字符串,但匹配可能的最少次數 

x+ 匹配 1 次或多次 x 字符串,但匹配可能的最少次數 

.* 匹配 0 次或一次的任何字符 

.+ 匹配 1 次或多次的任何字符 

{m} 匹配剛好是 m 個 的指定字符串 

{m,n} 匹配在 m個 以上 n個 以下 的指定字符串 

{m,} 匹配 m個 以上 的指定字符串 

[] 匹配符合 [] 內的字符 

[^] 匹配不符合 [] 內的字符 

[0-9] 匹配所有數字字符 

[a-z] 匹配所有小寫字母字符 

[^0-9] 匹配所有非數字字符 

[^a-z] 匹配所有非小寫字母字符 

^ 匹配字符開頭的字符 

$ 匹配字符結尾的字符 

/d 匹配一個數字的字符,和 [0-9] 語法一樣 

/d+ 匹配多個數字字符串,和 [0-9]+ 語法一樣 

/D 非數字,其他同 /d 

/D+ 非數字,其他同 /d+ 

/w 英文字母或數字的字符串,和 [a-zA-Z0-9] 語法一樣 

/w+ 和 [a-zA-Z0-9]+ 語法一樣 

/W 非英文字母或數字的字符串,和 [^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 匹配以英文字母,數字爲邊界的字符串 

/B 匹配不以英文字母,數值爲邊界的字符串 

a|b|c 匹配符合a字符 或是b字符 或是c字符 的字符串 

abc 匹配含有 abc 的字符串 

(pattern) () 這個符號會記住所找尋到的字符串,是一個很實用的語法。第一個 () 內所找到的字符串變成 $1 這個變量或是 /1 變量,第二個 () 內所找到的字符串變成 $2 這個變量或是 /2 變量,以此類推下去。  

/pattern/i i 這個參數表示忽略英文大小寫,也就是在匹配字符串的時候,不考慮英文的大小寫問題。 

/ 如果要在 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]/ 找到沒有這三個字符中任意一個的字符串 

//d/ 找尋符合數字的字符,可以使用//d+/來表示一個或是多個數字組成的字符串 

//D/ 找尋符合不是數字的字符,可以使用//D+/來表示一個或是更多個非數字組成的字符串 

//*/ 找尋符合 * 這個字符,因爲 * 在常規表達式中有它的特殊意思,所以要在這個特殊符號前加上 / 符號,這樣纔會讓這個特殊字符失效 

/abc/i 找尋符合 abc 的字符串而且不考慮這些字符串的大小寫 



 



9.3 正則表達式的八大原則

  如果在 Unix 中曾經使用過 sed、awk、grep 這些命令的話,相信對於 Perl 語言中的正則表達式(Regular Expression)不會感到陌生。Perl 語言由於有這個功能,所以對字符串的處理能力非常強。在Perl語言的程序中,經常可以看到正則表達式的運用,在 CGI 程序設計中也不例外。



  正則表達式是初學 Perl 的難點所在,不過只要一旦掌握其語法,你就可以擁有幾乎無限的模式匹配能力,而且 Perl 編程的大部分工作都是掌握常規表達式。下面給大家介紹幾條正則表達式使用過程中的 8 大原則。 



  正則表達式在對付數據的戰鬥中可形成龐大的聯盟——這常常是一場戰爭。我們要記住下面八條原則:



· 原則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' $a = 'as',$a =~ s/$varb/ /; 等價於 $a =~ s/a/ /; ,執行結果使 $a = " s" )。



· 原則5:正則表達式在求值過程中產生兩種情況:結果狀態和反向引用: $a=~ m/pattern/ 表示 $a 中是否有子串 pattern 出現,$a =~ s/(word1)(word2)/$2$1/ 則“調換”這兩個單詞。



· 原則6:正則表達式的核心能力在於通配符和多重匹配運算符以及它們如何操作。$a =~ m//w+/ 匹配一個或多個單詞字符;$a =~ m//d/" 匹配零個或多個數字。



· 原則7:如果欲匹配不止一個字符集合,Perl使用 "|" 來增加靈活性。如果輸入 m/(cat|dog)/ 則相當於“匹配字符串 cat 或者 dog。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章