Maison >développement back-end >tutoriel php >php使用正则表达式_PHP教程

php使用正则表达式_PHP教程

WBOY
WBOYoriginal
2016-07-13 17:18:351147parcourir

正则表达式在所有编程语言中都是比较重要的知识,php也提供了正则表达式可以通过正则来进行字符串查找和替换,基本上我们可以把java的正则用在php上

一 正则规范

1.常用的正则规范

\w 表示字母、数字、下划线

\W 表示非字母、数字、下划线

\d 表示数字

\D 表示非数字

\s 表示所有空白字符(换行、空格等)

\S 表示所有非空白字符

^ 行的开头(用于定界)

$ 行的结尾(用于定界)

. 匹配除换行之外的任意字符

[abc] 字符a,b,c

[^abc] 除了a,b,c之外的任意字符

[a-zA-Z0-9] 表示由字母、数字组成

\n 表示换行

\\ 表示反斜杠


2.数量表示(X表示一组规范)

X? 可以出现0次或1次

X+ 可以出现1次或多次

X* 可以出现0次、1次或多次

X{n} 必须出现n次

X{n,} 必须出现n次以上

X{n,m} 必须出现n至m次


3.逻辑运算符(X、Y表示一组规范)

XY X规范后跟着Y规范

(X) 作为一个捕获组规范(子表达式)

X|Y X规范或Y规范


二 php中怎样使用正则

1.使用正则表达式查找固定格式的字符

php提供了preg_match()和preg_match_all()两个方法供我们使用,使用这两个方法可以做字符串格式校验和查找

(1) 取出字符串里的所有四位数

使用之前要注意,php里规定我们把正则规范写在P的位置上 ‘/P/i’,先就取四位数这个举例,代码如下

echo "<h4><font color='red'>取出字符串里的所有四位数</font></h4>";
$str1="abcd1034yu3029";
preg_match_all('/\d{4}/i', $str1,$arr1);
foreach ($arr1[0] as $val){
	echo "$val"."<br/>";
}

要说明的是$arr1,这个是一个二维数组,php把匹配上的所有的字符放在这个数组里


(2)取出类似1111、3333这种格式的字符串

这种情况就要使用字表达式了,代码如下

echo "<h4><font color='red'>取出字符串里的4位数要求每位数字都相同,例如1111、4444、5555、6666</font></h4>";
$str2="abcd1034yu3029sd3333";
preg_match_all('/(\d)\1{3}/i', $str2,$arr2);
foreach ($arr2[0] as $val){
	echo "$val"."<br/>";
}
下面是两段代码的运行效果

\

(3)取出类似1111-2222-3333这种格式的字符串

echo "<h4><font color='red'>取出类似1111-2222-3333这种格式的字符串</font></h4>";
$str3="ab3333-5555-6666cd1034yu3029sd3333";
preg_match_all('/(\d)\1{3}-(\d)\2{3}-(\d)\3{3}/i', $str3,$arr3);
foreach ($arr3[0] as $val){
	echo "$val"."<br/>";
}

有兴趣可以使用print_r()打印下这个$arr3,里面有2个数组,第一个是匹配出来的字符串,第二个是字表达式的值

\

(4)来一个稍微复杂点的,取出类似1111-232-3333、1111-575-3333这种格式的字符串的最后4个数字

echo "<h4><font color='red'>取出类似1111-232-3333、1111-575-3333这种格式的字符串的最后4个数字</font></h4>";
$str4="ab3333-575-6666cd10348888-464-9999";
preg_match_all('/(\d)\1{3}-(\d)\d\2-(\d)\3{3}/i', $str4,$arr4);

foreach ($arr4[0] as $val){
	$nums=explode("-", $val);
	echo "$nums[2]"."<br/>";
}


\

(5)过滤重复字符喎?http://www.Bkjia.com/kf/ware/vc/" target="_blank" class="keylink">vcD4KPHA+PHByZSBjbGFzcz0="brush:java;">echo "

过滤重复的字符

"; $repeatstr="我爱爱和和平"; preg_match_all('/(\w)\1*/iu', $repeatstr,$arr); $finalStr=""; foreach ($arr[1] as $val){ $finalStr.=$val; }
/i后面的u表示一种规范,表示匹配UTF-8的字符,还有其他几种大家可以查看php开发文档

\

2.还有一种比较复杂的匹配叫环视匹配

表达式

说明

(?

逆序肯定环视,表示所在位置左侧能够匹配Expression

(?

逆序否定环视,表示所在位置左侧不能匹配Expression

(?=Expression)

顺序肯定环视,表示所在位置右侧能够匹配Expression

(?!Expression)

顺序否定环视,表示所在位置右侧不能匹配Expression


这个部分理解起来有点复杂,可以参考下下面这篇文章,里面有个剥取

中间内容的例子讲的还不错

http://blog.csdn.net/lxcnn/article/details/4304754


下面把我写的这一整个php页面贴出来

过滤重复的字符";
$repeatstr="我爱爱和和平";
preg_match_all('/(\w)\1*/iu', $repeatstr,$arr);
$finalStr="";
foreach ($arr[1] as $val){
	$finalStr.=$val;
}
echo $finalStr;
echo "<h4><font color='red'>取出字符串里的所有四位数</font></h4>";
$str1="abcd1034yu3029";
preg_match_all('/\d{4}/i', $str1,$arr1);
foreach ($arr1[0] as $val){
	echo "$val"."<br/>";
}
echo "<h4><font color='red'>取出字符串里的4位数要求每位数字都相同,例如1111、4444、5555、6666</font></h4>";
$str2="abcd1034yu3029sd3333";
preg_match_all('/(\d)\1{3}/i', $str2,$arr2);
foreach ($arr2[0] as $val){
	echo "$val"."<br/>";
}
echo "<h4><font color='red'>取出类似1111-2222-3333这种格式的字符串</font></h4>";
$str3="ab3333-5555-6666cd1034yu3029sd3333";
preg_match_all('/(\d)\1{3}-(\d)\2{3}-(\d)\3{3}/i', $str3,$arr3);
foreach ($arr3[0] as $val){
	echo "$val"."<br/>";
}
echo "<h4><font color='red'>取出类似1111-232-3333、1111-575-3333这种格式的字符串的最后4个数字</font></h4>";
$str4="ab3333-575-6666cd10348888-464-9999";
preg_match_all('/(\d)\1{3}-(\d)\d\2-(\d)\3{3}/i', $str4,$arr4);

foreach ($arr4[0] as $val){
	$nums=explode("-", $val);
	echo "$nums[2]"."<br/>";
}
echo "

验证是否是电子邮件

"; $email="chen@163.com"; preg_match_all('/^\w+@\w+\.\w+$/i', $email,$earr); if(count($earr[0])>0){ echo "$email"."是合法的电子邮件"; }else{ echo "$email"."是非法的电子邮件"; } ?>





www.bkjia.comtruehttp://www.bkjia.com/PHPjc/621637.htmlTechArticle正则表达式在所有编程语言中都是比较重要的知识,php也提供了正则表达式可以通过正则来进行字符串查找和替换,基本上我们可以把jav...
Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn