1、正規表示式的定義
2、正規表示式的幾個基本語法
正規表示式是對字串進行操作的一種邏輯公式,就是用一些特定的字元組合成一個規則字串
比如:
<?php $p = '/abc123/'; $str = "abc123bbbb"; if (preg_match($p, $str)) { echo '該字串符合這個規則'; } ?>
上述程式碼中的'/abc123/'就是一個正規表示式,我們從中可以看出,/abc123/就是一串由字元和數位組成的字串,只不過這些字元在裡面有其特殊的含義,比如/abc123/這個正規表示式的規則是,字串以abc123開頭,任何字串符合這個規則就它就和這個表示式相匹配了
1、正則匹配模式使用分隔符與元字元組成,分隔符可以是非數位、非反斜線、非空格的任意字元。常見的分隔符比如正斜線(/)、hash符號(#) 以及取反符號(~)
舉例如:
/hello world/ 表示式的意思是:字串以hellow world開頭
#^[0-9]$# 表示式的意思是:匹配0-9的數位
~hello~ 表示式的意思是:字串包含hello
我們用程式碼來測試一下
例一、
/hello world/ 表示式的意思是:字串以hellow world開頭
<?php $p = "/hello world/"; $str = "hello world,i am a student"; if (preg_match($p, $str)) { echo '該字串符合這個規則/hello world/<br/>'; } ?>
執行結果如下:
該字串符合這個規則/hello world/
換一個字串看下,不以hello world開頭
<?php $p = "/hello world/"; $str = "helloworld,i am a student"; if (preg_match($p, $str)) { echo '該字串符合這個規則/hello world/<br/>'; } ?>
執行結果為:
空白
例二、
#^[0-9]$# 表示式的意思是:匹配0-9的數位
<?php $p2 = "#^[0-9]$#"; $str2 = "3"; if (preg_match($p2, $str2)) { echo '該字串符合這個規則"#^[0-9]$#<br/>'; } ?>
執行結果為:
該字串符合這個規則"#^[0-9]$#
程式碼改一下,字串改成一個大於9的數位看下
<?php $p2 = "#^[0-9]$#"; $str2 = "30"; if (preg_match($p2, $str2)) { echo '該字串符合這個規則"#^[0-9]$#<br/>'; }else{ echo '該字串不符合這個規則"#^[0-9]$#<br/>'; } ?>
執行結果為:
該字串不符合這個規則"#^[0-9]$#
例三、
~hello~ 表示式的意思是:字串包含hello
具體程式碼如下:
<?php $p3 = "~hello~"; $str3 = "ahellobb"; if (preg_match($p3, $str3)) { echo '該字串符合這個規則:~hello~'; }else{ echo '該字串不符合這個規則:~hello~'; } ?>
執行結果為:
該字串符合這個規則:~hello~
現在把測試字串改成不包含hellow
具體程式碼如下:
<?php $p3 = "~hello~"; $str3 = "hell o"; if (preg_match($p3, $str3)) { echo '該字串符合這個規則:~hello~'; }else{ echo '該字串不符合這個規則:~hello~'; } ?>
執行結果為:
該字串不符合這個規則:~hello~
由此可見:
1、/表示開頭
2、^表示以^後面的字元開始
3、$表示以$前面的字元結束
4、~表示包含的意思
2、如果模式中包含分隔符,則分隔符需要使用反斜槓()進行跳脫。
比如:
/https://www./ 表示以https://www.開頭
具體程式碼如下:
<?php $p = "/https://www./"; $str = "https://www.baidu.com"; if (preg_match($p, $str)) { echo '該字串符合這個規則:/https://www./'; }else{ echo '該字串不符合這個規則:/https://www./'; }
執行結果為:
該字串符合這個規則:/https://www./
試著將字串 改成不以https://www.開頭看下
<?php $p = "/https://www./"; $str = "http://www.baidu.com"; if (preg_match($p, $str)) { echo '該字串符合這個規則:/https://www./'; }else{ echo '該字串不符合這個規則:/https://www./'; }
執行結果為:
該字串不符合這個規則:/https://www./
3、如果模式中包含較多的分割字元,建議更換其他的字元作為分隔符,也可以採用preg_quote進行跳脫。
例一、
<?php $p = "/https://www.baidu.com/a/b/index.html/"; $str = "http://www.baidu.com/a/b/index.html"; if (preg_match($p, $str)) { echo '該字串符合這個規則:/https://www.baidu.com/a/b/index.html/'; }else{ echo '該字串不符合這個規則:/https://www.baidu.com/a/b/index.html/'; }
執行結果為:
Warning: preg_match(): Unknown modifier '/' in D:E-classclass-codeclassingindex.php on line 7
該字串不符合這個規則:/https://www.baidu.com/a/b/index.html/
所以此時不能直接寫/要麼按照上面的進行跳脫,要麼按照下面的方式進行
具體程式碼如下:
<?php $p = "https://www.baidu.com/a/b/index.html"; $p = '/'.preg_quote($p, '/').'/'; $str = "https://www.baidu.com/a/b/index.html"; if (preg_match($p, $str)) { echo '該字串符合這個規則:/https://www.baidu.com/a/b/index.html/'; }else{ echo '該字串不符合這個規則:/https://www.baidu.com/a/b/index.html/'; } ?>
執行結果為:
該字串符合這個規則:/https://www.baidu.com/a/b/index.html/
4、分隔符後面可以使用模式修飾符,模式修飾符包括:i,m, s,等
總結:
1、i 表示可以忽略大小寫
2、m表示多行匹配
3、如果設定了此修正符,模式中的圓點元字元(.)匹配所有的字元,包括換行符。沒有此設定的話,則不包括換行符。
案例一、
實踐目標:
1、i 表示可以忽略大小寫
<?php $p = "/ABc/i"; $str = "abc"; if (preg_match($p, $str)) { echo '該字串符合這個規則:/ABc/i'; }else{ echo '該字串不符合這個規則:/ABc/i'; } ?>
執行結果為:
該字串符合這個規則:/ABc/i
案例二、
實踐目標:
1、m表示多行匹配
具體程式碼如下:
<?php $p = "/chinese/m"; $str = "i am a chinese people,n you alose is a chinese people"; $math = ""; if (preg_match_all($p, $str,$math)) { echo '該字串符合這個規則:/chinese/m,匹配結果為:'; print_r($math); }else{ echo '該字串不符合這個規則:/chinese/m'; } ?>
執行結果為:
該字串符合這個規則:/chinese/m,匹配結果為:Array ( [0] => Array ( [0] => chinese [1] => chinese ) )
這裡要注意的是一定要用preg_match_all否則用preg_match它只會匹配一行
接下來我們執行下效果
<?php $p = "/chinese/m"; $str = "i am a chinese people,n you alose is a chinese people"; $math = ""; if (preg_match($p, $str,$math)) { echo '該字串符合這個規則:/chinese/m,匹配結果為:'; print_r($math); }else{ echo '該字串不符合這個規則:/chinese/m'; } ?>
執行結果為:
該字串符合這個規則:/chinese/m,匹配結果為:Array ( [0] => chinese )
其實/m在此也算多此一舉,因為preg_match_all就是表示多行匹配了
<?php $p = "/chinese/"; $str = "i am a chinese people,n you alose is a chinese people"; $math = ""; if (preg_match_all($p, $str,$math)) { echo '該字串符合這個規則,匹配結果為:'; print_r($math); }else{ echo '該字串不符合這個規則'; } ?>
執行結果其實是一樣的,結果為:
該字串符合這個規則,匹配結果為:Array ( [0] => Array ( [0] => chinese [1] => chinese ) )
只是要知道m表示多行匹配的意思
案例三、
實踐目標:
1、如果設定了此修正符,模式中的圓點元字元(.)匹配所有的字元,包括換行符。沒有此設定的話,則不包括換行符。
具體程式碼如下:
<?php $p = "/chinese ./s"; $str = "i am a chinese n people, you alose is a chinese good people"; $math = ""; if (preg_match_all($p, $str,$math)) { echo '該字串符合這個規則,匹配結果為:'; print_r($math); }else{ echo '該字串不符合這個規則'; } ?>
執行結果如下:
該字串符合這個規則,匹配結果為:Array ( [0] => Array ( [0] => chinese [1] => chinese g ) )
說明第一個chinese 後面的字元是換行也匹配到了,這說明了s的意思就是.要包含換行符,接下來
我們去掉s,看下最終的結果
<?php $p = "/chinese ./"; $str = "i am a chinese n people, you alose is a chinese good people"; $math = ""; if (preg_match_all($p, $str,$math)) { echo '該字串符合這個規則,匹配結果為:'; print_r($math); }else{ echo '該字串不符合這個規則'; } ?>
執行結果如下:
該字串符合這個規則,匹配結果為:Array ( [0] => Array ( [0] => chinese g ) )
說明此刻只匹配到一個了,因為.不包含換行符,所以第一個chinese沒有匹配到
本文主要講解了
1、正規表示式的定義
2、正規表示式的幾個基本語法
以上就是PHP中正規表示式詳解(程式碼範例)的詳細內容,更多請關注TW511.COM其它相關文章!