《PHP應用:老生常談php 正則中的i,m,s,x,e分別表示什么》要點:
本文介紹了PHP應用:老生常談php 正則中的i,m,s,x,e分別表示什么,希望對您有用。如果有疑問,可以聯(lián)系我們。
i???????? ?
如果設定此修正符,模式中的字符將同時匹配大小寫字母.PHP實戰(zhàn)
m????? ?
當設定了此修正符,“行起始”和“行結束”除了匹配整個字符串開頭和結束外,還分別匹配其中的換行符的之后和之前.PHP實戰(zhàn)
s?????? ?
如果設定了此修正符,模式中的圓點元字符(.)匹配所有的字符,包括換行符.沒有此設定的話,則不包括換行符.PHP實戰(zhàn)
x??????? ?
如果設定了此修正符,模式中的空白字符除了被轉義的或在字符類中的以外完全被忽略,在未轉義的字符類之外的 #以及下一個換行符之間的所有字符,包括兩頭,也都被忽略.PHP實戰(zhàn)
e??????? ?
如果設定了此修正符,preg_replace() 在替換字符串中對逆向引用作正常的替換,PHP實戰(zhàn)
?在 . + 和 * 之后 表示非貪婪匹配: *、+和?限定符都是貪婪的,因為它們會盡可能多的匹配文字,只有在它們的后面加上一個?就可以實現(xiàn)非貪婪或最小匹配.PHP實戰(zhàn)
例如:PHP實戰(zhàn)
<?php $string = "上飛機離開我<img border='0' alt='' src='/uploadfile/2009/0921/20090921091612567.jpg' border='0' />sdfsdf"; $su = preg_match("/ \<[ ]*img.*src[ ]*\=[ ]*[\"|\'](.+?)[\"|\'] /", $string,$match); // 匹配src=的內(nèi)容 print_r($match[1]); // 輸出 /uploadfile/2009/0921/20090921091612567.jpg $su = preg_match("/ \<[ ]*img.*src[ ]*\=[ ]*[\"|\'](.+)[\"|\'] /", $string,$match); print_r($match[1]); // 輸出 /uploadfile/2009/0921/20090921091612567.jpg' border=' ?>
例子:(?i):PHP實戰(zhàn)
(?i)在PHP中的意思是內(nèi)部修正符,i指不區(qū)分大小寫PHP實戰(zhàn)
其它的修正符還有x,m,s,U等.和我們使用的模式修正符是一樣的.PHP實戰(zhàn)
區(qū)別在于它是在模式內(nèi)部使用的.僅作用于(?i)所在的子模式內(nèi)PHP實戰(zhàn)
如PHP實戰(zhàn)
ccc(a(?i))bcd 匹配 cccabcd和cccAbcdPHP實戰(zhàn)
而a(?i)bc則和abc加上\i修正符是一樣的因為(?i)作用于整個模式PHP實戰(zhàn)
后向引用PHP實戰(zhàn)
對一個正則表達式模式或部分模式兩邊添加圓括號將導致相關匹配存儲到一個臨時緩沖區(qū)中,所捕獲的每個子匹配都按照在正則表達式模式中從左至右所遇到的內(nèi)容存儲.存儲子匹配的緩沖區(qū)編號從 1 開始,連續(xù)編號直至最大 99 個子表達式.每個緩沖區(qū)都可以使用 '\n' 訪問,其中 n 為一個標識特定緩沖區(qū)的一位或兩位十進制數(shù).PHP實戰(zhàn)
可以使用非捕獲元字符 '?:', '?=', or '?!' 來忽略對相關匹配的保存.PHP實戰(zhàn)
以上這篇老生常談php 正則中的i,m,s,x,e分別表示什么就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持維易PHP.PHP實戰(zhàn)
轉載請注明本頁網(wǎng)址:
http://www.fzlkiss.com/jiaocheng/1528.html