常用的php正则表达及语法注解总结-php教程

资源魔 32 0
根本语法

界定符:

标识一个正则表白式的开端以及完结,用'/'或'#'或'{ }',由于语法'{ }'也多是正则表白式的运算符,为了不混杂,以是没有倡议应用。倡议的用法以下:

Copy$pattern = '/[0-9]/';  //我喜爱这个,看起来比拟简约 $pattern = '#[0-9]#';

原子:

可见原子:Unicode编码表中可用键盘输入后肉眼可见的字符,例如:标点 ; . / ? 或许英文字母,汉字等等可见字符
不成见原子:Unicode编码表中可用键盘输入后肉眼不成见的字符,例如:换行符 \n,Tab制表符\t, 空格等等,
普通只用这三个(换行符普通以及其余字符一同婚配,由于只有换行符是婚配没有到的)
小提醒:婚配运算符后面需求加 '\' 例如:'+' 号,婚配的话需求写出 '\+'

元字符

原子的挑选形式:

| 婚配两个或许多个分支抉择
[] 婚配方括号中的恣意一个原子
[^] 婚配除了方括号中的原子以外的恣意字符;
例子:Duang|duang 或许 [Dd]uang 均可以婚配到Duang以及duang
区间写法:[a-z]婚配a到z的字符, [0-9]婚配0到9的字符。也能够[a-z0-9]
. 婚配除了换行符以外的恣意字符
\d 婚配恣意一个十进制数字,即{0-9]
\D 婚配恣意一个非十进制数字[^0-9] 相称于[^\d]
\s 婚配一个不成见的原子,即[\f\n\r\t\v]
\S 婚配一个可见的原子,即[\f\n\r\t\v],相称于[\s]z
\w 婚配恣意一个数字、字母或下划线,即[0-9a-zA-Z_]
\W 婚配恣意一个非数字、字母或下划线,[0-9a-zA-Z_],相称于[\w]

量词

{n} 示意其后面的原子刚好呈现了n次。
[n] 示意其后面的原子起码呈现n次
{n,m} 起码呈现n次,最多呈现m次
* 婚配0次、一次或许屡次,即{0,}
+ 婚配一次或屡次,即{1,}
? 婚配0或1次,即{0,1}

鸿沟管制

^ 婚配字符串开端的地位
$ 婚配字符串末端的地位
例:^John 能够婚配到:John 然而婚配没有到:123John,由于规则了字符串以John扫尾

模式单位

() 婚配此中的全体为一个原子, 如: (X|x)iaomi , 能够婚配到 xiaomi

修改模式

贪心婚配

婚配后果存正在歧义时取其长(默许)

懈怠婚配

婚配后果存正在歧义时取其短,只要正在正则表白式的前面'/'加之'U',例如'/[0-9]/U';
例子:

Copy$subject = "test__123123123";
preg_match('/test.+123/', $subject, $matches); //贪心模式  var_dump($matches);
preg_match('/test.+123/U', $subject, $matches); //懈怠模式var_dump($matches);

常见的修改模式:

U 懈怠婚配
i 疏忽英文字母的巨细写
x 疏忽正则表白式的空缺符
s 让元字符'.' 婚配包罗换行符正在内的一切字符

罕用函数

preg_match

执行婚配正则表白式

preg_match ( string $pattern , string $subject [, array &$matches [, int $flags = 0 [, int $offset = 0 ]]] ) : int

pattern: 要搜寻的模式,字符串类型。subject:输出字符串。match: 假如提供了参数matches,它将被填充为搜寻后果,数据构造为一维数组。flags: 能够设置为PREG_OFFSET_CAPTURE,应用搜寻后果的第0个元素为婚配的字符串,第1个元素为对应的偏偏移量(地位)offset: 搜寻从指标字符串的肇始地位开端婚配。

前往值:婚配次数
相似函数preg_match_all,参数与preg_match分歧
区分:

preg_match:只婚配一次,搜寻构造match的数据后果为一维数组preg_match_all:婚配全副,搜寻后果match的数据构造为二维数组。

preg_replace

执行一个正则表白式搜寻以及交换,前往值为交换后的字符串

preg_replace ( mixed $pattern , mixed $replacement , mixed $subject [, int $limit = -1 [, int &$count ]] ) : mixed

pattern:要搜寻的模式。能够是一个字符串或字符串数组。replacement:用于交换的字符串或字符串数组subject:要进行搜寻以及交换的字符串或字符串数组。limit:交换的最年夜次数。默许是 -1(有限)。count:交换次数。
相似函数preg_filter,参数与preg_replace分歧
区分(应用数组进行婚配的时分才看患上出区分):preg_replace:不论能否有交换,前往全副后果preg_filter:只前往婚配的后果。

preg_split

经过一个正则表白式分隔字符串

preg_split ( string $pattern , string $subject [, int $limit = -1 [, int $flags = 0 ]] ) : array

$pattrn:用于搜寻的模式,字符串方式。subject:输出字符串limit:将限度分隔失去的子串最多只有limit个,前往的最初一个 子串将蕴含一切残余局部。flags:有如下标志的组合:
-- 1. PREG_SPLIT_NO_EMPTY: 前往分隔后的非空局部。
-- 2. PREG_SPLIT_DELIM_CAPTURE: 用分隔符'()'括号把婚配的捕捉并前往。
-- 3. PREG_SPLIT_OFFSET_CAPTURE: 婚配前往时将会附加字符串偏偏移量

PREG_SPLIT_DELIM_CAPTURE这个参数可能比拟难懂白,举个例子看看:

Copy$subject = "1a23b";  
$a = preg_split('/[\d]/', $subject, -1, PREG_SPLIT_NO_EMPTY);  
var_dump($a);  
$a = preg_split('/([\d])/', $subject, -1, PREG_SPLIT_NO_EMPTY | PREG_SPLIT_DELIM_CAPTURE); 
var_dump($a);

输入以下:

array (size=2)
0 => string 'a' (length=1)
1 => string 'b' (length=1)
array (size=5)
0 => string '1' (length=1)
1 => string 'a' (length=1)
2 => string '2' (length=1)
3 => string '3' (length=1)
4 => string 'b' (length=1)

preg_grep

前往婚配模式的数组条款

preg_grep ( string $pattern , array $input [, int $flags = 0 ] ) : array

$pattern:要搜寻的模式,字符串方式$input:输出数组flags:假如没有设置则前往婚配的数量,设置PREG_GREP_INVERT则前往没有婚配的数量。

preg_quote

本义正则表白式字符,前往为本义后的字符串

preg_quote ( string $str [, string $delimiter = NULL ] ) : string

str:输出字符串delimiter:需求本义的字符串

以上就是罕用的php正则表白及语法注解总结的具体内容,更多请存眷资源魔其它相干文章!

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

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