本文實例總結了php常用正則函數。分享給大家供大家參考,具體如下:
1. mixed preg_replace(mixed pattern, mixed replacement, mixed subject, [, int limit])
函數功能:用於正則表達式的搜索和替換。
pattern:正則表達式。
replacement:替換的內容。
subject:需要匹配替換的對象。
limit:可選,指定替換的個數,如果省略 limit 或者其值為 -1,則所有的匹配項都會被替換。
補充說明
① replacement 可以包含 \\n 形式或 $n 形式的逆向引用,首選使用後者。每個此種引用將被替換為與第 n 個被捕獲的括號內的子模式所匹配的文本。n 可以從 0 到 99,其中 \\0 或 $0 指的是被整個模式所匹配的文本。對左圓括號從左到右計數(從 1 開始)以取得子模式的數目。
② 對替換模式在一個逆向引用後面緊接著一個數字時(如 \\11),不能使用 \\ 符號來表示逆向引用。因為這樣將會使 preg_replace() 搞不清楚是想要一個 \\1 的逆向引用後面跟著一個數字 1 還是一個 \\11 的逆向引用。解決方法是使用 \${1}1。這會形成一個隔離的 $1 逆向引用,而使另一個 1 只是單純的文字。
③ 上述參數除 limit 外都可以是一個數組。如果 pattern 和 replacement 都是數組,將以其鍵名在數組中出現的順序來進行處理,這不一定和索引的數字順序相同。如果使用索引來標識哪個 pattern 將被哪個 replacement 來替換,應該在調用 preg_replace() 之前用 ksort() 函數對數組進行排序。
例子 1 :
<?php $str = "The quick brown fox jumped over the lazy dog."; $str = preg_replace('/\s/','-',$str); echo $str; ?>
輸出結果為:
The-quick-brown-fox-jumped-over-the-lazy-dog.
例子 2 ,使用數組:
<?php $str = "The quick brown fox jumped over the lazy dog."; $patterns[0] = "/quick/"; $patterns[1] = "/brown/"; $patterns[2] = "/fox/"; $replacements[2] = "bear"; $replacements[1] = "black"; $replacements[0] = "slow"; print preg_replace($patterns, $replacements, $str); /*輸出: The bear black slow jumped over the lazy dog. */ ksort($replacements); print preg_replace($patterns, $replacements, $str); /*輸出: The slow black bear jumped over the lazy dog. */ ?>
例子 3 ,使用逆向引用:
<?php $str = '<a href="http://www.baidu.com/">baidu</a>其他字符<a href="http://www.sohu.com/">sohu</a>'; $pattern = "/<a\s([\s\S]*?)>([\s\S]*?)<\/a>/i"; print preg_replace($pattern, '\\2', $str); ?>
輸出結果為:
baidu其他字符sohu
該例子演示了將文本中所有的 <a></a> 標簽去掉。
2. int preg_match(string $pattern, string $subject [,array &$matches [, int $flags=0 [ ,int $offset=0]]])
函數功能:搜索subject與pattern給定的正則表達式的一個匹配。
pattern:要搜索的模式,字符串類型。
subject:輸入字符串。
matches:如果提供了參數matches,它將被填充為搜索結果,$matches[0]將包含完整模式匹配到文本,$matches[1]將包含第一捕獲子組匹配到的文本。
flags:可以設置為PREG_OFFSET_CAPTURE,如果傳遞了這個標記,對於每一個出現的匹配返回時會附加字符串偏移量(相對於目標字符串的)。
注意:這會改變填充到matches數組,使其每個元素成為一個由第0個元素是匹配到的字符串,第1個元素是該匹配字符串在目標字符串subject中的偏移量。
offset:通常,搜索從目標字符串的開始,可選參數offset用於指定從目標字符串的某個未知開始搜索(單位是字節)。
3. int preg_match_all(string $pattern, string $subject [, array &$matches [, int $flags=PREG_PATTERN_ORDER [, int $offset=0]]])
函數功能:搜索subject中所有匹配pattern給定正則表達式的匹配結果並且將它們以flag指定順序輸出到matches中。
在第一個匹配找到後,子序列繼續從最後一次匹配位置搜索。
pattern:要搜索的模式,字符串形式。
subject:輸入字符串。
matches:多維數組,作為輸出參數輸出後所有匹配結果,數組排序通過flags指定。
flags:可以結合下面標記使用(注意不能同時使用PREG_PATTERN_ORDER和PREG_SET_ORDER):
PREG_PATTERN_ORDER
結果排序為$matches[0]保存完整模式的所有匹配,$matches[1] 保存第一個子組的所有匹配, 以此類推.
<?php preg_match_all("|<[^>]+>(.*)</[^>]+>|U", "<b>example: </b><div align=left>this is a test</div>", $out, PREG_PATTERN_ORDER); echo $out[0][0] . ", " . $out[0][1] . "\n"; echo $out[1][0] . ", " . $out[1][1] . "\n"; ?>
以上例程會輸出:
<b>example: </b>, <div align=left>this is a test</div>
example: , this is a test
因此, $out[0]是包含匹配完整模式的字符串的數組,$out[1]是包含閉合標簽內的字符串的數組.
PREG_SET_ORDER
結果排序為$matches[0]包含第一次匹配得到的所有匹配(包含子組),$matches[1]是包含第二次匹配到的所有匹配(包含子組)的數組, 以此類推.
<?php preg_match_all("|<[^>]+>(.*)</[^>]+>|U", "<b>example: </b><div align=\"left\">this is a test</div>", $out, PREG_SET_ORDER); echo $out[0][0] . ", " . $out[0][1] . "\n"; echo $out[1][0] . ", " . $out[1][1] . "\n"; ?>
以上例程會輸出:
<b>example: </b>, example:
<div align="left">this is a test</div>, this is a test
PREG_OFFSET_CAPTURE
如果這個標記被傳遞, 每個發現的匹配返回時會增加它相對目標字符串的偏移量. 注意這會改變matches中的每一個匹配結果字符串元素, 使其 成為一個第0個元素為匹配結果字符串, 第1個元素為 匹配結果字符串在subject中的偏移量.
如果沒有給定排序標記, 假定設置為PREG_PATTERN_ORDER.
offset:通常,查找時從目標字符串的開始位置開始,可選參數offset用於從目標字符串中指定位置開始搜索(單位是字節)。
PS:這裡再為大家提供2款非常方便的正則表達式工具供大家參考使用:
JavaScript正則表達式在線測試工具:
http://tools.jb51.net/regex/javascript
正則表達式在線生成工具:
http://tools.jb51.net/regex/create_reg
更多關於PHP相關內容感興趣的讀者可查看本站專題:《php正則表達式用法總結》、《PHP數組(Array)操作技巧大全》、《PHP基本語法入門教程》、《PHP運算與運算符用法總結》、《php面向對象程序設計入門教程》、《PHP網絡編程技巧總結》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》
希望本文所述對大家PHP程序設計有所幫助。