php中使用正则表达式PCRE

本文详细介绍了正则表达式的语法及使用方法,包括各种元字符的功能、模式修正符的作用、以及PHP中常用的正则表达式函数如preg_match_all、preg_match和preg_replace的具体应用。

第七章 正则表达式PCRE

正则表达式的语法规则

正则表达式描述了一类字符串的特征,通过这个特征与特定函数的结合,对其他字符串进行匹配、查找、替换以及分割的操作

这类字符串的特征是由一个到多个普通字符(a-z)或元字符(±*/)组成

‘/a/’,其中/为定界符表示开始和结束

preg_match_all()按指定的正则表达式,在给定的字符串进行搜索,匹配到符合特征的部分取出来

<?php
$pattern='/test/';
$str='abtestc';
var_dump(preg_match_all($pattern,$str,$arr));//在str中找pattern,返回值为有几个
var_dump($arr);//有一个就输出一个数组

定界符

我们一般使用正斜线“/”做为定界符也可以用#|等等,放在正则表达式的起始位置,前后一致。

普通字符

比如 a-z A-Z 0-9 双引号、单引号,没有特殊含义。

单双引号要用\引义

元字符

\d代表0-9等任意一个十进制数字

<?php
$pattern='/te\dst/';
$str='abte9stc';
var_dump(preg_match_all($pattern,$str,$arr));//在str中找pattern,返回值为有几个
var_dump($arr);

\D匹配除了0-9的任意一个十进制数字

<?php
$pattern='/te\sst/';
$str='abte stc';
var_dump(preg_match_all($pattern,$str,$arr));//在str中找pattern,返回值为有几个
var_dump($arr);

\s匹配任意一个空白字符,如换行符,回车符,制表符,垂直制表符等

使用\n的字符串外面需要用双引号

\S匹配除了空白字符的其他字符

\w匹配任意一个数字或者字母或下划线,\W相反

<?php
$pattern='/te\wst/';
$str='abte_stc';
var_dump(preg_match_all($pattern,$str,$arr));//在str中找pattern,返回值为有几个
var_dump($arr);

.匹配任意一个除换行符(\n)的字符

<?php
$pattern='/te.st/';
$str='abte_stc';
var_dump(preg_match_all($pattern,$str,$arr));//在str中找pattern,返回值为有几个
var_dump($arr);//arr中存放符合特征的字符数组

匹配点可以使用转义

<?php
$pattern='/te\.st/';
$str='abte.stc';
var_dump(preg_match_all($pattern,$str,$arr));//在str中找pattern,返回值为有几个
var_dump($arr);

*匹配0次,一次,或者多次

*前面那个字符可以出现0次,1次或者多次

<?php
$pattern='/te*st/';
$str='abteeeeeestc';
var_dump(preg_match_all($pattern,$str,$arr));//在str中找pattern,返回值为有几个
var_dump($arr);

+匹配一次,或者多次

+前面那个字符可以出现1次或者多次

?匹配0次,一次

?前面那个字符可以出现0次,1次

{n}表示它前面的字符恰好出现n次

{n:}表示前面的字符出现不小于n次

{n,m}表示前面的字符至少出现n次,至多出现m次

^或\A匹配字符串开始的位置

比如下面那个例子,必须要以test开头

<?php
$pattern='/^test/';
$str='testabteeeeeestc';
var_dump(preg_match_all($pattern,$str,$arr));//在str中找pattern,返回值为有几个
var_dump($arr);//放置匹配到的元素用数组储存

$或\Z匹配字符串结尾的位置

<?php
$pattern='/test$/';
$str='abteeeeeestctest';
var_dump(preg_match_all($pattern,$str,$arr));//在str中找pattern,返回值为有几个
var_dump($arr);//放置匹配到的元素用数组储存

$与^配合使用

<?php
$pattern='/^te.*st$/';
$str='testabteeeeeestctest';
var_dump(preg_match_all($pattern,$str,$arr));//在str中找pattern,返回值为有几个
var_dump($arr);//放置匹配到的元素用数组储存

|匹配两个或多个特征

下面这个例子可以匹配abc或者test

<?php
$pattern='/test|abc/';
$str='testabteeeabceeestctest';
var_dump(preg_match_all($pattern,$str,$arr));//在str中找pattern,返回值为有几个
var_dump($arr);//放置匹配到的元素用数组储存

[]匹方括号中的任意一个字符

<?php
$pattern='/t[tewr]st/';
$str='testabteeeabceeestctest';
var_dump(preg_match_all($pattern,$str,$arr));//在str中找pattern,返回值为有几个
var_dump($arr);//放置匹配到的元素用数组储存

[^]匹配除了方括号外的任意一个字符

<?php
$pattern='/t[^tewr]st/';
$str='tastabteeeabceeestctest';
var_dump(preg_match_all($pattern,$str,$arr));//在str中找pattern,返回值为有几个
var_dump($arr);//放置匹配到的元素用数组储存

()将括号中作为一个整体以便其中内容获取到

在正则表达式中 可以使用圆括号来将某一段括起来,在圆括号的后面部分,我们可以使用\数字 来代表圆括号部分所匹配到的内容

<?php
$pattern='/t(e)st\\1/';//'\\1'代表第一个圆括号匹配到的内容,相当于teste
$str='   teste         ';
var_dump(preg_match_all($pattern,$str,$arr));//在str中找pattern,返回值为有几个
var_dump($arr);//放置匹配到的元素用数组储存
<?php
$pattern='/t(.)(.)t\\1\\2/';//'\\1'代表第一个圆括号匹配到的内容
$str='   testes         ';
var_dump(preg_match_all($pattern,$str,$arr));//在str中找pattern,返回值为有几个
var_dump($arr);//放置匹配到的元素用数组储存

模式修正符

在定界符之后,增强正则表达式的功能

i 在和模式进行匹配时不区分大小写

<?php
$pattern='/test/i';//'\\1'代表第一个圆括号匹配到的内容
$str='   test Test TEst TesT         ';
var_dump(preg_match_all($pattern,$str,$arr));//在str中找pattern,返回值为有几个
var_dump($arr);//放置匹配到的元素用数组储存

m 多行匹配,如果目标字符中没有“\n"字符,或者模式中没有出现^或$,设置这个装饰符不产生任何影响

使用条件:1.目标字符串包含\n 2.正则表达式中必须出现^或$

<?php
$pattern='/^test/m';
$str="test\ntest\ntest\ntest         ";
var_dump(preg_match_all($pattern,$str,$arr));//在str中找pattern,返回值为有几个
var_dump($arr);//放置匹配到的元素用数组储存

ps:在windows操作系统中看到的换行包括\r \n来完成

<?php
$pattern='/^test\r*/m';
$str="test
test
test
test         ";
var_dump(preg_match_all($pattern,$str,$arr));//在str中找pattern,返回值为有几个
var_dump($arr);//放置匹配到的元素用数组储存

s:如果设定了此修正符,那么将匹配所有的字符包括换行符

<?php
$pattern='/t.st/s';//
$str="t\nst";
var_dump(preg_match_all($pattern,$str,$arr));//在str中找pattern,返回值为有几个
var_dump($arr);//放置匹配到的元素用数组储存

U禁止贪婪匹配

贪婪匹配:尽可能多的去匹配

<?php
$pattern='/a.*f/U';//等价于'/a.*?f/' 不加u有2个加u只有一个
$str="adssf asdsdsdasdaf";
var_dump(preg_match_all($pattern,$str,$arr));//在str中找pattern,返回值为有几个
var_dump($arr);//放置匹配到的元素用数组储存

模式修正符可以搭配使用

与正则表达式匹配的函数

preg_match_all

preg_match_all:找到所有符合条件的

第四个参数(可选)

第五个参数(可选)

<?php
$pattern='/t(.*?)st/';//等价于'/a.*?f/' 不加u有2个加u只有一个
$str="   test    tewffadsdst test tareehst";
var_dump(preg_match_all($pattern,$str,$arr));//在str中找pattern,返回值为有几个
var_dump($arr);//放置匹配到的元素用数组储存

preg_match

preg_match:只找一次,返回值是0或1(执行一个正则表达式匹配)

参数说明(正则表达式,目标字符串,放一个变量存放匹配到的数据,0或PREG_OFFSET_CAPTURE)

第四个参数默认是0,如果传了PREG_OFFSET_CAPTURE则第三个参数那个变量的数据就会有匹配到的部分偏移值

还可以传第五个参数:传一个值来表示从目标字符串的哪个位置开始搜索(单位是字节)

<?php
$pattern='/t(.*?)st/';//等价于'/a.*?f/' 不加u有2个加u只有一个
$str="   test    tewffadsdst test tareehst";
var_dump(preg_match($pattern,$str,$arr,PREG_OFFSET_CAPTURE));//在str中找pattern,返回值为有几个
var_dump($arr);//放置匹配到的元素用数组储存

preg_replace

参数说明

​ 第一个参数:正则表达式

​ 第二个参数:要替换成的字符串

​ 第三个参数:目标字符串


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值