請問下那此句語句的作用。給我解釋一下其中的“?”,“e","i","s"符號分別是什麼意思,和它們起到了什麼作用。還有就是除了"/eis”外還有其他什麼模式了嗎?
如果有相關的學習資料可以給我嗎?謝謝,各位的協助!謝謝。
$post=preg_replace("/\[html\](.+?)\[\/html\]/eis","htmlcode('\\1')",$post);
修飾符:
在Regex裡面的修飾符可以改變正則的很多特性,使得Regex更加適合你的需要(注意:修飾符對於大小寫是敏感的,這意味著"e"並不等於"E")。Regex裡面的修飾符如下:
i :如果在修飾符中加上"i",則正則將會取消大小寫敏感性,即"a"和"A" 是一樣的。
m:預設的正則開始"^"和結束"$"只是對於正則字串如果在修飾符中加上"m",那麼開始和結束將會指字串的每一行:每一行的開頭就是"^",結尾就是"$"。
s:如果在修飾符中加入"s",那麼預設的"."代表除了分行符號以外的任何字元將會變成任一字元,也就是包括分行符號!
x:如果加上該修飾符,運算式中的空白字元將會被忽略,除非它已經被轉義。
e:本修飾符僅僅對於replacement有用,代表在replacement中作為PHP代碼。
A:如果使用這個修飾符,那麼運算式必須是匹配的字串中的開頭部分。比如說"/a/A"匹配"abcd"。
E:與"m"相反,如果使用這個修飾符,那麼"$"將匹配絕對字串的結尾,而不是分行符號前面,預設就開啟了這個模式。
U:和問號的作用差不多,用於設定"貪婪模式"。
?表單非貪婪匹配,即儘可能少的匹配和
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]
中間的內容
e表示可以使用函數來處理向後引後的子匹配部分
i表未不區分大小寫,
s表示.也匹配分行符號
假設有如下字串 this is a text
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]this is another text
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]
使用/\[html\](.+?)\[\/html\]/和使用[html\](.+)\[\/html\]/U的結果是一樣的,
都是代表非貪婪,只不過一個用了修正符,一個用了文法。
結果是this is a text
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]
和this is another text
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]
兩個匹配,
而/\[html\](.+)\[\/html\]/的結果是 this is a text
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]this is another text
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]
一個匹配
因為整個字元也是符合以""開頭以"
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]
"結尾,只不過是獲得更多的字串