首頁 >後端開發 >php教程 >淺談PHP的正規表示式

淺談PHP的正規表示式

青灯夜游
青灯夜游轉載
2019-01-05 09:54:014197瀏覽

這篇文章跟大家介紹一下PHP的正規表示式,有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。

心智圖

 點選下圖,可以看特定內容!

介紹

正則表達式,大家在開發中應該是常用到,現在很多開發語言都有正規表示式的應用,比如javascript,java,.net,php等等,我今天就把我對正則表達式的理解跟大家嘮嘮,不當之處,請多多指教!

需要知道的術語-下面的術語你知道多少?

Δ  定界符

Δ  字元域

Δ  修飾符

Δ  限定詞

Δ  脫字

Δ  通配符(正向預查,反向預查)

#Δ  反向引用

Δ  惰性匹配

Δ  註解

Δ  零字元寬

定位

##我們什麼時候使用正規表示式呢?不是所有的字元操作都用正規就好了,php在某些方面用正則反而影響效率。當我們遇到

複雜文字資料的解析時候,用正規是比較好的選擇。

優點

正規表示式在處理複雜字元操作的時候,可以

提高工作效率,也在一定程度節省你的程式碼量

缺點

我們在使用正規表示式的時候,複雜的正規表示式會加大程式碼的

複雜度,讓人很難理解。所以我們有的時候需要在正規表示式內部加入註解。

通用模式

¤ 定界符,通常使用"/"做為定界符開始和結束,也可以使用"# "。

什麼時候使用"#"呢?一般是在你的字串中有

很多"/"字元的時候,因為正規的時候這種字元需要轉義,例如uri 。

使用"/"定界符的程式碼如下.

$regex = '/^http:\/\/([\w.]+)\/([\w]+)\/([\w]+)\.html$/i';
$str = 'http://www.youku.com/show_page/id_ABCDEFG.html';
$matches = array();

if(preg_match($regex, $str, $matches)){
    var_dump($matches);
}

echo "\n";

preg_match中的$matches[0]將包含與整個模式相符的字串。

使用"#"定界符的程式碼如下。這個時候

對"/"就不轉義!

$regex = '#^http://([\w.]+)/([\w]+)/([\w]+)\.html$#i';
$str = 'http://www.youku.com/show_page/id_ABCDEFG.html';
$matches = array();

if(preg_match($regex, $str, $matches)){
    var_dump($matches);
}

echo "\n";

¤ 修飾符:用於改變正規表示式的行為。


我們看到的('/^http:\/\/([\w.] )\/([\w] )\/([\w] )\.html/

i')中的最後一個"i"就是修飾符,表示忽略大小寫,還有一個我們常用到的是"x"表示忽略空格。

貢獻程式碼:

$regex = '/HELLO/';
$str = 'hello word';
$matches = array();

if(preg_match($regex, $str, $matches)){
    echo 'No i:Valid Successful!',"\n";
}

if(preg_match($regex.'i', $str, $matches)){
    echo 'YES i:Valid Successful!',"\n";
}

 ¤ 字元域:[\w]用方括號擴充的部分就是字元域。


 ¤ 限定詞:如[\w]{3,5}或[\w]*或[\w] 這些[\w]後面的符號都表示限定符。現介紹具體意義。


     {3,5}表示3到5個字元。 {3,}超過3個字符,{,5}最多5個,{3}三個字符。

     * 表示0到多個

     表示1到多個。

¤ 脫字符號


      ^:

          >放在在字元中(如:[^\w])中表示否定(不包括的意思) ——「反向選擇」

          >  放在表達式之前,以目前這個字元開始。 (/^n/i,表示以n開頭)。

注意,我們常常管"\"叫"跳出字元"。用於轉義一些特殊符號,如".","/"

通配符(lookarounds):斷言某些字串中某些字元的存在與否!

 lookarounds分成兩種:lookaheads(正向預查 ?=)和lookbehinds(反向預查?3862f7e5e596227f24782fcf6de045db 格式:

正向預查:(?=) 相對應的(?!)表示否定意思

反向預查:(?67305373ea0633e2ab5029a82167ea86字符宽度:零

验证零字符代码

$regex = '/HE(?=L)LO/i';
$str = 'HELLO';
$matches = array();

if(preg_match($regex, $str, $matches)){
    var_dump($matches);
}

echo "\n";

打印不出结果!

$regex = '/HE(?=L)LLO/i';
$str = 'HELLO';
$matches = array();

if(preg_match($regex, $str, $matches)){
    var_dump($matches);
}

echo "\n";

 能打印出结果!

说明:(?=L)意思是HE后面紧跟一个L字符。但是(?=L)本身不占字符,要与(L)区分,(L)本身占一个字符。

捕获数据

没有指明类型而进行的分组,将会被获取,供以后使用。

> 指明类型指的是通配符。所以只有圆括号起始位置没有问号的才能被捕捉。

> 在同一个表达式内的引用叫做反向引用。

> 调用格式: \编号(如\1)。

$regex = '/^(Chuanshanjia)[\w\s!]+\1$/';    
$str = 'Chuanshanjia thank Chuanshanjia';
$matches = array();

if(preg_match($regex, $str, $matches)){
    var_dump($matches);
}

echo "\n";

> 避免捕获数据

   格式:(?:pattern)

   优点:将使有效反向引用数量保持在最小,代码更加、清楚。

>命名捕获组

   格式:(?P5e64257b369329e4ba4d555318eb64af) 调用方式 (?P=组名)

$regex = &#39;/(?P<author>chuanshanjia)[\s]Is[\s](?P=author)/i&#39;;
$str = &#39;author:chuanshanjia Is chuanshanjia&#39;;
$matches = array();

if(preg_match($regex, $str, $matches)){
    var_dump($matches);
}

echo "\n";

运行结果

惰性匹配(记住:会进行两部操作,请看下面的原理部分)

  格式:限定符?

     原理:"?":如果前面有限定符,会使用最小的数据。如“*”会取0个,而“+”会取1个,如过是{3,5}会取3个。

先看下面的两个代码:

代码1.

<?php
$regex = &#39;/heL*/i&#39;;
$str = &#39;heLLLLLLLLLLLLLLLL&#39;;
if(preg_match($regex, $str, $matches)){
    var_dump($matches);
}

echo "\n";

结果1.

代码2

<?php
$regex = &#39;/heL*?/i&#39;;
$str = &#39;heLLLLLLLLLLLLLLLL&#39;;
if(preg_match($regex, $str, $matches)){
    var_dump($matches);
}

echo "\n";

结果2

代码3,使用“+”

<?php
$regex = &#39;/heL+?/i&#39;;
$str = &#39;heLLLLLLLLLLLLLLLL&#39;;
if(preg_match($regex, $str, $matches)){
    var_dump($matches);
}

echo "\n";

结果3

代码4,使用{3,5}

<?php
$regex = &#39;/heL{3,10}?/i&#39;;
$str = &#39;heLLLLLLLLLLLLLLLL&#39;;
if(preg_match($regex, $str, $matches)){
    var_dump($matches);
}

echo "\n";

结果4

正则表达式的注释

格式:(?# 注释内容)

用途:主要用于复杂的注释

贡献代码:是一个用于连接MYSQL数据库的正则表达式

$regex = &#39;/
    ^host=(?<!\.)([\d.]+)(?!\.)                 (?#主机地址)
\|
    ([\w!@#$%^&*()_+\-]+)                       (?#用户名)
\|
    ([\w!@#$%^&*()_+\-]+)                       (?#密码)
(?!\|)$/ix&#39;;

$str = &#39;host=192.168.10.221|root|123456&#39;;
$matches = array();

if(preg_match($regex, $str, $matches)){
    var_dump($matches);
}

echo "\n";

特殊字符 

特殊字符 解释
* 0到多次
+ 1到多次还可以写成{1,}
? 0或1次
. 匹配除换行符外的所有单个的字符
\w [a-zA-Z0-9_]
\s 空白字符(空格,换行符,回车符)[\t\n\r]
\d [0-9]

案例汇总

 1、PHP中文匹配

<?php
$str = "PHP编程";
if (preg_match("/([0-9a-zA-Z\x{4e00}-\x{9fa5}]+)/u",$str, $matches)) {
    var_dump($matches);
    echo "\n";
}

 以上就是本篇文章的全部内容,希望能对大家的学习有所帮助。更多精彩内容大家可以关注php中文网相关教程栏目!!!

以上是淺談PHP的正規表示式的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:cnblogs.com。如有侵權,請聯絡admin@php.cn刪除