91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PHP中正則表達式介紹

發布時間:2020-06-01 20:45:05 來源:億速云 閱讀:245 作者:鴿子 欄目:編程語言

正則表達式的定義

正則表達式是對字符串進行操作的一種邏輯公式,就是用一些特定的字符組合成一個規則字符串

比如:

<?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-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 = '/'.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沒有匹配到

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

肇东市| 平江县| 禹州市| 黎城县| 宁武县| 伊宁市| 万宁市| 武夷山市| 青河县| 沅陵县| 潜江市| 师宗县| 个旧市| 库车县| 温宿县| 来凤县| 门源| 山西省| 清涧县| 城口县| 中山市| 武宁县| 台前县| 莎车县| 新郑市| 姚安县| 灵寿县| 古田县| 日土县| 太湖县| 固始县| 陵水| 宁城县| 谷城县| 樟树市| 永登县| 高雄市| 贵阳市| 泸溪县| 都昌县| 屏东县|