首頁  >  文章  >  後端開發  >  PHP中正規表示式詳解(程式碼實例)

PHP中正規表示式詳解(程式碼實例)

易达
易达原創
2020-05-29 21:32:102923瀏覽

本文目標:

1、正規表示式的定義

2、正規表示式的幾個基本語法

(一)、正規表示式的定義

正規表示式是對字串進行運算的一種邏輯公式,就是用一些特定的字元組合成一個規則字串

例如:

<?php
$p = &#39;/abc123/&#39;;
$str = "abc123bbbb";
if (preg_match($p, $str)) {
    echo &#39;该字符串符合这个规则&#39;;
}
?>

上述程式碼中的'/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 &#39;该字符串符合这个规则/hello world/<br/>&#39;;
}

?>

運行結果如下:

該字串符合這個規則/hello world/

換一個字串看下,不以hello world開頭

<?php
$p = "/hello world/";
$str = "helloworld,i am a student";
if (preg_match($p, $str)) {
    echo &#39;该字符串符合这个规则/hello world/<br/>&#39;;
}

?>

運行結果為:

#空白

範例二##、#^[0-9]$#     表達式的意思是:符合0-9的數字

<?php
$p2 = "#^[0-9]$#";
$str2 = "3";
if (preg_match($p2, $str2)) {
    echo &#39;该字符串符合这个规则"#^[0-9]$#<br/>&#39;;
}
?>

運算結果為:

該字串符合這個規則"#^[0-9]$


#程式碼改一下,字串改成一個大於9的數字看下
<?php
$p2 = "#^[0-9]$#";
$str2 = "30";
if (preg_match($p2, $str2)) {
    echo &#39;该字符串符合这个规则"#^[0-9]$#<br/>&#39;;
}else{
    echo &#39;该字符串不符合这个规则"#^[0-9]$#<br/>&#39;;
}
?>

運行結果為:

該字串不符合這個規則"#^[0-9]$

##例三、

#~hello~          表達式的意思是:字串包含hello

具體程式碼如下:

<?php
$p3 = "~hello~";
$str3 = "ahellobb";
if (preg_match($p3, $str3)) {
    echo &#39;该字符串符合这个规则:~hello~&#39;;
}else{
    echo &#39;该字符串不符合这个规则:~hello~&#39;;
}
?>

運行結果為:

#該字串符合這個規則:~hello~

現在把測試字串改成不包含hellow

具體程式碼如下:

<?php
$p3 = "~hello~";
$str3 = "hell o";
if (preg_match($p3, $str3)) {
    echo &#39;该字符串符合这个规则:~hello~&#39;;
}else{
    echo &#39;该字符串不符合这个规则:~hello~&#39;;
}
?>

運行結果為:

該字串不符合這個規則:~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 &#39;该字符串符合这个规则:/https:\/\/www./&#39;;
}else{
    echo &#39;该字符串不符合这个规则:/https:\/\/www./&#39;;
}

運行結果為:

該字串符合這個規則:/https:\/\/www./

#將字串改成不以
https://www.開頭看下

<?php
$p = "/https:\/\/www./";
$str = "http://www.baidu.com";
if (preg_match($p, $str)) {
    echo &#39;该字符串符合这个规则:/https:\/\/www./&#39;;
}else{
    echo &#39;该字符串不符合这个规则:/https:\/\/www./&#39;;
}
運行結果為:

該字串不符合這個規則: /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 &#39;该字符串符合这个规则:/https://www.baidu.com/a/b/index.html/&#39;;
}else{
    echo &#39;该字符串不符合这个规则:/https://www.baidu.com/a/b/index.html/&#39;;
}
運行結果為:

Warning: preg_match(): Unknown modifier '/' in D:\E-class\class-code\classing\index.php on line 7
該字串不符合這個規則:/https://www.baidu.com/a/b/index.html/


所以此時不能直接寫/要麼按照上面的進行轉義,要麼按照下面的方式進行

具體程式碼如下:

<?php
$p = "https://www.baidu.com/a/b/index.html";
$p = &#39;/&#39;.preg_quote($p, &#39;/&#39;).&#39;/&#39;;
$str = "https://www.baidu.com/a/b/index.html";
if (preg_match($p, $str)) {
    echo &#39;该字符串符合这个规则:/https://www.baidu.com/a/b/index.html/&#39;;
}else{
    echo &#39;该字符串不符合这个规则:/https://www.baidu.com/a/b/index.html/&#39;;
}
?>

運行結果為:


該字串符合這個規則:/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 &#39;该字符串符合这个规则:/ABc/i&#39;;
}else{
    echo &#39;该字符串不符合这个规则:/ABc/i&#39;;
}
?>

運行結果為:


該字串符合這個規則:/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 &#39;该字符串符合这个规则:/chinese/m,匹配结果为:&#39;;
    print_r($math);
}else{
    echo &#39;该字符串不符合这个规则:/chinese/m&#39;;
}
?>

運行結果為:

該字串符合這個規則:/ 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 &#39;该字符串符合这个规则:/chinese/m,匹配结果为:&#39;;
    print_r($math);
}else{
    echo &#39;该字符串不符合这个规则:/chinese/m&#39;;
}
?>

运行结果为:

该字符串符合这个规则:/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 &#39;该字符串符合这个规则,匹配结果为:&#39;;
    print_r($math);
}else{
    echo &#39;该字符串不符合这个规则&#39;;
}

?>

运行结果其实是一样的,结果为:

该字符串符合这个规则,匹配结果为: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 &#39;该字符串符合这个规则,匹配结果为:&#39;;
    print_r($math);
}else{
    echo &#39;该字符串不符合这个规则&#39;;
}
?>

运行结果如下:

该字符串符合这个规则,匹配结果为: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 &#39;该字符串符合这个规则,匹配结果为:&#39;;
    print_r($math);
}else{
    echo &#39;该字符串不符合这个规则&#39;;
}
?>

运行结果如下:

该字符串符合这个规则,匹配结果为:Array ( [0] => Array ( [0] => chinese g ) )

说明此刻只匹配到一个了,因为.不包含换行符,所以第一个chinese没有匹配到

总结:

本文主要讲解了

1、正则表达式的定义

2、正则表达式的几个基本语法

以上是PHP中正規表示式詳解(程式碼實例)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn