PHP中正则表达式详解(代码实例)-php教程

资源魔 15 0

本文指标:

一、正则表白式的界说

二、正则表白式的几个根本语法

(一)、正则表白式的界说

正则表白式是对字符串进行操作的一种逻辑公式,就是用一些特定的字符组分解一个规定字符串

比方:

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

上述代码中的'/abc123/'就是一个正则表白式,咱们从中能够看出,/abc123/就是一串由字符以及数字组成的字符串,只不外这些字符正在外面有其非凡的含意,比方/abc123/这个正则表白式的规定是,字符串以abc123扫尾,任何字符串合乎这个规定就它就以及这个表白式相婚配了

(二)、正则表白式的几个根本语法

一、正则婚配模式应用分隔符与元字符组成,分隔符能够长短数字、非反斜线、非空格的恣意字符。常见的分隔符比方正斜线(/)、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]$#

例3、

~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~

因而可知:

一、/示意扫尾

二、^示意以^前面的字符开端

三、$示意以$后面的字符完结

四、~示意蕴含的意义

二、假如模式中蕴含分隔符,则分隔符需求应用反斜杠(\)进行本义。

比方:

/https:\/\/www./ 示意以https://www.扫尾

详细代码以下:

<?php
$p = "/https:\/\/www./";
$str = "https://www.百度.com";
if (preg_match($p, $str)) {
    echo '该字符串合乎这个规定:/https:\/\/www./';
}else{
    echo '该字符串没有合乎这个规定:/https:\/\/www./';
}

运转后果为:

该字符串合乎这个规定:/https:\/\/www./

试着将字符串 改为没有以https://www.扫尾看下

<?php
$p = "/https:\/\/www./";
$str = "http://www.百度.com";
if (preg_match($p, $str)) {
    echo '该字符串合乎这个规定:/https:\/\/www./';
}else{
    echo '该字符串没有合乎这个规定:/https:\/\/www./';
}

运转后果为:

该字符串没有合乎这个规定:/https:\/\/www./

三、假如模式中蕴含较多的宰割字符,倡议改换其余的字符作为分隔符,也能够采纳preg_quote进行本义。

例1、

<?php

$p = "/https://www.百度.com/a/b/index.html/";
$str = "http://www.百度.com/a/b/index.html";
if (preg_match($p, $str)) {
    echo '该字符串合乎这个规定:/https://www.百度.com/a/b/index.html/';
}else{
    echo '该字符串没有合乎这个规定:/https://www.百度.com/a/b/index.html/';
}

运转后果为:

Warning: preg_match(): Unknown modifier '/' in D:\E-class\class-code\classing\index.php on line 7
该字符串没有合乎这个规定:/https://www.百度.com/a/b/index.html/

以是此时不克不及间接写/要末依照下面的进行本义,要末依照上面的形式进行

详细代码以下:

<?php
$p = "https://www.百度.com/a/b/index.html";
$p = '/'.preg_quote($p, '/').'/';
$str = "https://www.百度.com/a/b/index.html";
if (preg_match($p, $str)) {
    echo '该字符串合乎这个规定:/https://www.百度.com/a/b/index.html/';
}else{
    echo '该字符串没有合乎这个规定:/https://www.百度.com/a/b/index.html/';
}
?>

运转后果为:

该字符串合乎这个规定:/https://www.百度.com/a/b/index.html/

四、分隔符前面能够应用模式润饰符,模式润饰符包罗:i,m, s,等

总结:

一、i 示意能够疏忽巨细写

二、m示意多行婚配

三、假如设定了此修改符,模式中的圆点元字符(.)婚配一切的字符,包罗换行符。不此设定的话,则没有包罗换行符。

案例1、

理论指标:

一、i 示意能够疏忽巨细写

<?php
$p = "/ABc/i";
$str = "abc";
if (preg_match($p, $str)) {
    echo '该字符串合乎这个规定:/ABc/i';
}else{
    echo '该字符串没有合乎这个规定:/ABc/i';
}
?>

运转后果为:

该字符串合乎这个规定:/ABc/i

案例2、

理论指标:

一、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示意多行婚配的意义

案例3、

理论指标:

一、假如设定了此修改符,模式中的圆点元字符(.)婚配一切的字符,包罗换行符。不此设定的话,则没有包罗换行符。

详细代码以下:

<?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不婚配到

总结:

本文次要解说了

一、正则表白式的界说

二、正则表白式的几个根本语法

以上就是PHP中正则表白式详解(代码实例)的具体内容,更多请存眷资源魔其它相干文章!

标签: php php开发教程 php开发资料 php开发自学 正则表达式

抱歉,评论功能暂时关闭!