正則表達(dá)式是對(duì)字符串進(jìn)行操作的一種邏輯公式,就是用一些特定的字符組合成一個(gè)規(guī)則字符串
祁門網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián)建站,祁門網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為祁門上1000家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\外貿(mào)營(yíng)銷網(wǎng)站建設(shè)要多少錢,請(qǐng)找那個(gè)售后服務(wù)好的祁門做網(wǎng)站的公司定做!
比如:
上述代碼中的'/abc123/'就是一個(gè)正則表達(dá)式,我們從中可以看出,/abc123/就是一串由字符和數(shù)字組成的字符串,只不過(guò)這些字符在里面有其特殊的含義,比如/abc123/這個(gè)正則表達(dá)式的規(guī)則是,字符串以abc123開(kāi)頭,任何字符串符合這個(gè)規(guī)則就它就和這個(gè)表達(dá)式相匹配了
1、正則匹配模式使用分隔符與元字符組成,分隔符可以是非數(shù)字、非反斜線、非空格的任意字符。常見(jiàn)的分隔符比如正斜線(/)、hash符號(hào)(#) 以及取反符號(hào)(~)
舉例如:
/hello world/ 表達(dá)式的意思是:字符串以hellow world開(kāi)頭
#^[0-9]$# 表達(dá)式的意思是:匹配0-9的數(shù)字
~hello~ 表達(dá)式的意思是:字符串包含hello
我們用代碼來(lái)測(cè)試一下
例一、
/hello world/ 表達(dá)式的意思是:字符串以hellow world開(kāi)頭
'; } ?>
運(yùn)行結(jié)果如下:
該字符串符合這個(gè)規(guī)則/hello world/
換一個(gè)字符串看下,不以hello world開(kāi)頭
'; } ?>
運(yùn)行結(jié)果為:
空白
例二、
#^[0-9]$# 表達(dá)式的意思是:匹配0-9的數(shù)字
'; } ?>
運(yùn)行結(jié)果為:
該字符串符合這個(gè)規(guī)則"#^[0-9]$#
代碼改一下,字符串改成一個(gè)大于9的數(shù)字看下
'; }else{ echo '該字符串不符合這個(gè)規(guī)則"#^[0-9]$#
'; } ?>
運(yùn)行結(jié)果為:
該字符串不符合這個(gè)規(guī)則"#^[0-9]$#
例三、
~hello~ 表達(dá)式的意思是:字符串包含hello
具體代碼如下:
運(yùn)行結(jié)果為:
該字符串符合這個(gè)規(guī)則:~hello~
現(xiàn)在把測(cè)試字符串改成不包含hellow
具體代碼如下:
運(yùn)行結(jié)果為:
該字符串不符合這個(gè)規(guī)則:~hello~
由此可見(jiàn):
1、/表示開(kāi)頭
2、^表示以^后面的字符開(kāi)始
3、$表示以$前面的字符結(jié)束
4、~表示包含的意思
2、如果模式中包含分隔符,則分隔符需要使用反斜杠(\)進(jìn)行轉(zhuǎn)義。
比如:
/https:\/\/www./ 表示以https://www.開(kāi)頭
具體代碼如下:
運(yùn)行結(jié)果為:
該字符串符合這個(gè)規(guī)則:/https:\/\/www./
試著將字符串 改成不以https://www.開(kāi)頭看下
運(yùn)行結(jié)果為:
該字符串不符合這個(gè)規(guī)則:/https:\/\/www./
3、如果模式中包含較多的分割字符,建議更換其他的字符作為分隔符,也可以采用preg_quote進(jìn)行轉(zhuǎn)義。
例一、
運(yùn)行結(jié)果為:
Warning: preg_match(): Unknown modifier '/' in D:\E-class\class-code\classing\index.php on line 7
該字符串不符合這個(gè)規(guī)則:/https://www.baidu.com/a/b/index.html/所以此時(shí)不能直接寫/要么按照上面的進(jìn)行轉(zhuǎn)義,要么按照下面的方式進(jìn)行
具體代碼如下:
運(yùn)行結(jié)果為:
該字符串符合這個(gè)規(guī)則:/https://www.baidu.com/a/b/index.html/
4、分隔符后面可以使用模式修飾符,模式修飾符包括:i,m, s,等
總結(jié):
1、i 表示可以忽略大小寫
2、m表示多行匹配
3、如果設(shè)定了此修正符,模式中的圓點(diǎn)元字符(.)匹配所有的字符,包括換行符。沒(méi)有此設(shè)定的話,則不包括換行符。
案例一、
實(shí)踐目標(biāo):
1、i 表示可以忽略大小寫
運(yùn)行結(jié)果為:
該字符串符合這個(gè)規(guī)則:/ABc/i
案例二、
實(shí)踐目標(biāo):
1、m表示多行匹配
具體代碼如下:
運(yùn)行結(jié)果為:
該字符串符合這個(gè)規(guī)則:/chinese/m,匹配結(jié)果為:Array ( [0] => Array ( [0] => chinese [1] => chinese ) )
這里要注意的是一定要用preg_match_all否則用preg_match它只會(huì)匹配一行
接下來(lái)我們運(yùn)行下效果
運(yùn)行結(jié)果為:
該字符串符合這個(gè)規(guī)則:/chinese/m,匹配結(jié)果為:Array ( [0] => chinese )
其實(shí)/m在此也算多此一舉,因?yàn)閜reg_match_all就是表示多行匹配了
運(yùn)行結(jié)果其實(shí)是一樣的,結(jié)果為:
該字符串符合這個(gè)規(guī)則,匹配結(jié)果為:Array ( [0] => Array ( [0] => chinese [1] => chinese ) )
只是要知道m(xù)表示多行匹配的意思
案例三、
實(shí)踐目標(biāo):
1、如果設(shè)定了此修正符,模式中的圓點(diǎn)元字符(.)匹配所有的字符,包括換行符。沒(méi)有此設(shè)定的話,則不包括換行符。
具體代碼如下:
運(yùn)行結(jié)果如下:
該字符串符合這個(gè)規(guī)則,匹配結(jié)果為:Array ( [0] => Array ( [0] => chinese [1] => chinese g ) )
說(shuō)明第一個(gè)chinese 后面的字符是換行也匹配到了,這說(shuō)明了s的意思就是.要包含換行符,接下來(lái)
我們?nèi)サ魋,看下最終的結(jié)果
運(yùn)行結(jié)果如下:
該字符串符合這個(gè)規(guī)則,匹配結(jié)果為:Array ( [0] => Array ( [0] => chinese g ) )
說(shuō)明此刻只匹配到一個(gè)了,因?yàn)?不包含換行符,所以第一個(gè)chinese沒(méi)有匹配到
當(dāng)前題目:PHP中正則表達(dá)式介紹
當(dāng)前網(wǎng)址:http://weahome.cn/article/jpjpei.html