仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 1112|回复: 18
打印 上一主题 下一主题

[学习教程] PHP网页编程之在PHP中利用与Perl兼容的正则表达式

[复制链接]
因胸联盟 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-2-4 00:20:28 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
我是根据自己的成长历程来写的,如有不对的还请指正。perl|正则   1 媒介
PHP被大批的使用于Web的后台CGI开辟,凡是是在用户数据数据以后得出某种了局,然而假如用户输出的数据不准确,就会呈现成绩,好比说或人的诞辰是"2月30日"!那应当怎样来查验寒假是不是准确呢? 在PHP中到场了正则表达式的撑持,让咱们可以非常便利的停止数据婚配。

2 甚么是正则表达式:
复杂的说,正则表达式是一种可以用于形式婚配和交换的壮大东西。在几近一切的基于UNIX/LINUX体系的软件东西中找到正则表达式的陈迹,例如:Perl或PHP剧本言语。另外,JavaScript这类客户真个剧本言语也供应了对正则表达式的撑持,如今正则表达式已成了一个通用的概念和东西,被各类手艺人员所普遍利用。
在某个Linux网站下面有如许的话:"假如你问一下Linux喜好者最喜好甚么,他能够会回覆正则表达式;假如你问他最惧怕甚么,除繁琐的装置设置装备摆设外他一定会说正则表达式。"
正如下面说的,正则表达式看起来十分庞杂,让人惧怕,大多半的PHP初学者城市跳过这里,持续上面的进修,然而PHP中的正则表达式有着可以使用形式婚配找到合适前提的字符串、判别字符串是不是符合前提或用指定的字符串来替换合适前提的字符串等壮大的功效,不学其实太惋惜了……


3 正则表达式的根基语法:
一个正则表达式,分为三个局部:分隔符,表达式和润色符。
分隔符可所以除特别字符之外的任何字符(好比"/ !"等等),经常使用的分隔符是"/"。表达式由一些特别字符(特别字符详见上面)和非特别的字符串构成,好比"[a-z0-9_-]+@[a-z0-9_-.]+"可以婚配一个复杂的电子邮件字符串。润色符是用来开启或封闭某种功效/形式。上面就是一个完全的正则表达式的例子:
/hello.+?hello/is
下面的正则表达式"/"就是分隔符,两个"/"之间的就是表达式,第二个"/"前面的字符串"is"就是润色符。
在表达式中假如含有分隔符,那末就需求利用本义符号"\",好比"/hello.+?\/hello/is"。本义符号除用于分隔符外还可以履行特别字符,全体由字母组成的特别字符都需求"\"来本义,好比"\d"代表全部数字。


4 正则表达式的特别字符:
正则表达式中的特别字符分为元字符、定位字符等等。
元字符是正则表达式中一类有特别意义的字符,用来描写其前导字符(即元字符后面的字符)在被婚配的对象中呈现的体例。元字符自己是一个个单一的字符,然而分歧或不异的元字符组合起来可以组成大的元字符。
元字符:
大括号:大括号用来准确指定婚配元字符呈现的次数,例如"/pre{1,5}/"暗示婚配的对象可所以"pre"、"pree"、"preeeee"如许在"pr"前面呈现1个到5个"e"的字符串。或"/pre{,5}/"代表pre呈现0此到5次之间。
加号:"+"字符用来婚配元字符前的字符呈现一次或屡次。例如"/ac+/"暗示被婚配的对象可所以"act"、"account"、"acccc"等在"a"前面呈现一个或多个"c"的字符串。"+"相当于"{1,}"。
星号:"*"字符用来婚配元字符前的字符呈现零次或屡次。例如"/ac*/"暗示被婚配的对象可所以"app"、"acp"、"accp"等在"a"前面呈现零个或多个"c"的字符串。"*"相当于"{0,}"。
问号:"?"字符用来婚配元字符前的字符呈现零次或1次。例如"/ac?/"暗示婚配的对象可所以"a"、"acp"、"acwp"如许在"a"前面呈现零个或1个"c"的字符串。"?"在正则表达式中还有一个十分主要的感化,即"贪心形式"。

还有两个很主要的特别字符就是"[ ]"。他们可以婚配"[]"当中呈现过的字符,好比"/[az]/"可以婚配单个字符"a"或"z";假如把下面的表达式改成如许"/[a-z]/",就能够婚配任何单个小写字母,好比"a"、"b"等等。
假如在"[]"中呈现了"^",代表本表达式不婚配"[]"内呈现的字符,好比"/[^a-z]/"不婚配任何小写字母!而且正则表达式给出了几种"[]"的默许值:
[:alpha:]:婚配任何字母
[:alnum:]:婚配任何字母和数字
[:digit:]:婚配任何数字
[:space:]:婚配空格符
[:upper:]:婚配任何大写字母
[:lower:]:婚配任何小写字母
[:punct:]:婚配任何标点符号
[:xdigit:]:婚配任何16进制数字

别的上面这些特别字符在本义符号"\"本义儿女表的寄义以下:
s:婚配单个的空格符
S:用于婚配除单个空格符以外的一切字符。
d:用于婚配从0到9的数字,相当于"/[0-9]/"。
w:用于婚配字母,数字或下划线字符,相当于"/[a-zA-Z0-9_]/"。
W:用于婚配一切与w不婚配的字符,相当于"/[^a-zA-Z0-9_]/"。
D:用于婚配任何非10进制的数字字符。
.:用于婚配除换行符以外的一切字符,假如经由润色符"s"的润色,"."可以代表恣意字符。

使用下面的特别字符可以很便利的表达一些对照繁琐的形式婚配。例如"/\d0000/"使用下面的正则表达式可以婚配万以上,十万一下的整数字符串。

定位字符:
定位字符是正则表达式中又一类十分主要的字符,它的次要感化是用于对字符在婚配对象中的地位停止描写。
^:暗示婚配的形式呈现在婚配对象的开首(和在"[]"外面分歧)
$:暗示婚配的形式呈现在婚配对象的末尾
空格:暗示婚配的形式呈现在入手下手和开头的两个界限之一
"/^he/":可以婚配以"he"字符开首的字符串,好比hello、height等等;
"/he$/":可以婚配以"he"字符开头的字符串即she等;
"/ he/":空格开首,和^的感化一样,婚配以he开首的字符串;
"/he /":空格停止,和$的感化一样,婚配以he开头的字符串;
"/^he$/":暗示只和字符串"he"婚配。

括号:
正则表达式除可以用户婚配,还可以用括号"()"来纪录需求的信息,贮存起来,给前面的表达式读取。好比:
/^([a-zA-Z0-9_-]+)@([a-zA-Z0-9_-]+)(.[a-zA-Z0-9_-])$/
就是纪录邮件地址的用户名,和邮件地址的办事器地址(模式为username@server.com之类的),在前面假如想要读取纪录上去的字符串,只是需求用"本义符+纪录的次第"来读取。好比"\1"就相当于第一个"[a-zA-Z0-9_-]+","\2"相当于第二个([a-zA-Z0-9_-]+),"\3"就是第三个(.[a-zA-Z0-9_-])。然而在PHP中,"\"是一个特别的字符,需求本义,所以""到了PHP的表达式中就应当写成"\\1"。
其他特别符号:
"|":或符号"|"和PHP外面的或一样,不外是一个"|",而不是PHP的两个"||"!意思就是可所以某个字符或另外一个字符串,好比"/abcd|dcba/"能够婚配"abcd"或"dcba"。


5 贪心形式:
后面在元字符中提到过"?"还有一个主要的感化,即"贪心形式",甚么是"贪心形式"呢?
好比咱们要婚配以字母"a"开首字母"b"开头的字符串,然而需求婚配的字符串在"a"前面含有良多个"b",好比"a bbbbbbbbbbbbbbbbb",那正则表达式是会婚配第一个"b"仍是最初一个"b"呢?假如你利用了贪心形式,那末会婚配到最初一个"b",反之只是婚配到第一个"b"。
利用贪心形式的表达式以下:
/a.+?b/
/a.+b/U
不利用贪心形式的以下:
/a.+b/
下面利用了一个润色符U,详见上面的局部。


6 润色符:
在正则表达式外面的润色符可以改动正则的良多特征,使得正则表达式加倍合适你的需求(注重:润色符关于巨细写是敏感的,这意味着"e"其实不等于"E")。正则表达式外面的润色符以下:
i :假如在润色符中加上"i",则正则将会作废巨细写敏理性,即"a"和"A" 是一样的。
m:默许的正则入手下手"^"和停止"$"只是关于正则字符串假如在润色符中加上"m",那末入手下手和停止将会指字符串的每行:每行的开首就是"^",开头就是"$"。
s:假如在润色符中到场"s",那末默许的"."代表除换行符之外的任何字符将会酿成恣意字符,也就是包含换行符!
x:假如加上该润色符,表达式中的空白字符将会被疏忽,除非它已被本义。
e:本润色符仅仅关于replacement有效,代表在replacement中作为PHP代码。
A:假如利用这个润色符,那末表达式必需是婚配的字符串中的开首局部。好比说"/a/A"婚配"abcd"。
E:与"m"相反,假如利用这个润色符,那末"$"将婚配相对字符串的开头,而不是换行符后面,默许就翻开了这个形式。
U:和问号的感化差不多,用于设置"贪心形式"。


7 PCRE相干的正则表达式函数:
PHP的Perl兼容正则表达式供应的多个函数,分为形式婚配,交换和婚配数量等等:
1、preg_match :
函数格局:int preg_match(string pattern, string subject, array [matches]);
这个函数会在string中利用pattern表达式来婚配,假如给定了[regs],就会将string纪录到[regs][0]中,[regs][1]代表利用括号"()"纪录上去的第一个字符串,[regs][2]代表纪录上去的第二个字符串,以此类推。preg假如在string中找到了婚配的pattern,就会前往"true",不然前往"false"。

2、preg_replace :
函数格局:mixed preg_replace(mixed pattern, mixed replacement, mixed subject);
这个函数会利用将string中合适表达式pattern的字符串全体交换为表达式replacement。假如replacement中需求包括pattern的局部字符,则可使用"()"来纪录,在replacement中只是需求用"\1"来读取。

3、preg_split :
函数格局:array preg_split(string pattern, string subject, int [limit]);
这个函数和函数split一样,区分仅在与split可使用复杂正则表达式来朋分婚配的字符串,而preg_split利用完整的Perl兼容正则表达式。第三个参数limit代表答应前往几何个合适前提的值。

4、preg_grep :
函数格局:array preg_grep(string patern , array input);
这个函数和preg_match功效根基上,不外preg_grep可以将给定的数组input中的一切元素婚配,前往一个新的数组。

上面举一个例子,好比咱们要反省Email地址的格局是不是准确:


<?php
function emailIsRight($email) {
if (preg_match("^[_\.0-9a-z-]+@([0-9a-z][0-9a-z-]+\.)+[a-z]{2,3}$",$email)) {
return 1;
}
return 0;
}
if(emailIsRight('y10k@963.net')) echo '准确<br>';
if(!emailIsRight('y10k@fffff')) echo '不准确<br>';
?>


下面的法式会输入"准确<br>不准确"。

8.PHP中的Perl兼容正则表达式和Perl/Ereg正则表达式的区分:
固然叫做“Perl兼容正则表达式”,然而和Perl的正则表达式比拟,PHP的仍是由一些分歧,好比润色符“G”在Perl外面代表全体婚配,然而在PHP中没有到场对这个润色符的撑持。
还有就是和ereg系列函数的区分,ereg也是PHP中供应的正则表达式函数,不外和preg比拟,要弱上良多。

1、ereg外面是不需求也不克不及利用分隔符和润色符的,所以ereg的功效比preg要弱上很多。
2、关于".":点在正则外面通常为除换行符之外的全体字符,然而在ereg外面的"."是恣意字符,即包含换行符!假如在preg外面但愿"."可以包含换行符,可以在润色符中加上"s"。
3、ereg默许利用贪心形式,而且不克不及修正,这个给良多交换和婚配带来费事。
4、速度:这个也许是良多人关怀的成绩,会不会preg功效壮大是以速度来换取的?不必忧虑,preg的速度要远远比ereg快,笔者做了一个法式测试:

time test:

PHP代码:

<?php
echo "Preg_replace used time:";
$start = time();
for($i=1;$i<=100000;$i++) {
$str = "ssssssssssssssssssssssssssss";
preg_replace("/s/","",$str);
}
$ended = time()-$start;
echo $ended;
echo "
ereg_replace used time:";
$start = time();
for($i=1;$i<=100000;$i++) {
$str = "ssssssssssssssssssssssssssss";
ereg_replace("s","",$str);
}
$ended = time()-$start;
echo $ended;
echo "
str_replace used time:";
$start = time();
for($i=1;$i<=100000;$i++) {
$str = "sssssssssssssssssssssssssssss";
str_replace("s","",$str);
}
$ended = time()-$start;
echo $ended;
?>
了局:
Preg_replace used time:5
ereg_replace used time:15
str_replace used time:2

str_replace由于不需求婚配所以速度十分快,而preg_replace的速度比ereg_replace要快上很多。


9.关于PHP3.0关于preg的撑持:
在PHP 4.0中默许到场了preg撑持,然而在3.0中确没有。假如在3.0中但愿利用preg函数,必需加载php3_pcre.dll文件,只需在php.ini的extension局部设置到场"extension = php3_pcre.dll"然后重新启动PHP就能够了!
其实正则表达式还经常使用于UbbCode的完成,良多PHP服装论坛都利用了这个办法(好比zForum zphp.com或vB vbullent.com),然而详细的代码对照长。  参加PHP开发学习,或许只是一次偶然的想法吧!只是想在走向社会之前体验、学习在一个公司或者说是项目团队之中如何去更有效的沟通、交流、共同合作,还有就是为毕业实习找工作增加伐码。
简单生活 该用户已被删除
沙发
发表于 2015-2-4 11:57:44 | 只看该作者
兴趣是最好的老师,百度是最好的词典。
深爱那片海 该用户已被删除
板凳
发表于 2015-2-9 22:29:08 | 只看该作者
php是动态网站开发的优秀语言,在学习的时候万万不能冒进。在系统的学习前,我认为不应该只是追求实现某种效果,因为即使你复制他人的代码调试成功,实现了你所期望的效果,你也不了解其中的原理。
老尸 该用户已被删除
地板
发表于 2015-2-11 10:30:09 | 只看该作者
首先声明:我是一个菜鸟,是一个初学者。学习了一段php后总是感觉自己没有提高,无奈。经过反思我认为我学习过程中存在很多问题,我改变了学习方法后自我感觉有了明显的进步。
admin 该用户已被删除
5#
发表于 2015-2-27 10:26:39 | 只看该作者
至于模板嘛,各位高人一直以来就是争论不休,我一只小菜鸟就不加入战团啦,咱们新手还是多学点东西的好。
山那边是海 该用户已被删除
6#
发表于 2015-3-7 11:58:23 | 只看该作者
最后介绍一个代码出错,但是老找不到错误方法,就是 go to wc (囧),出去换换气没准回来就找到错误啦。
柔情似水 该用户已被删除
7#
发表于 2015-3-8 10:53:54 | 只看该作者
爱上php,他也会爱上你。
冷月葬花魂 该用户已被删除
8#
发表于 2015-3-15 22:06:51 | 只看该作者
其实也不算什么什么心得,在各位大侠算是小巫见大巫了吧,望大家不要见笑,若其中有错误的地方请各位大虾斧正。
飘灵儿 该用户已被删除
9#
发表于 2015-3-17 15:52:44 | 只看该作者
这些中手常用的知识,当你把我说的这些关键字都可以熟练运用的时候,你可以选择自己
谁可相欹 该用户已被删除
10#
发表于 2015-3-21 13:09:01 | 只看该作者
最后祝愿,php会给你带来快乐的同时 你也会给他带来快乐。
透明 该用户已被删除
11#
发表于 2015-3-27 17:11:20 | 只看该作者
首先我是坚决反对新手上来就用框架的,因为对底层的东西一点都不了解,造成知识上的真空,会对以后的发展不利。我的观点上手了解下框架就好,代码还是手写。当然啦如果是位别的编程语言的高手的话,这个就另当别论啦。
小女巫 该用户已被删除
12#
发表于 2015-4-11 16:46:21 | 只看该作者
开发工具也会慢慢的更专业,每个公司的可能不一样,但是zend studio是个大伙都会用的。
海妖 该用户已被删除
13#
发表于 2015-4-13 04:34:32 | 只看该作者
真正的方向了,如果将来要去开发团队,你一定要学好smarty ,phplib这样的模板引擎,
乐观 该用户已被删除
14#
发表于 2015-4-17 18:20:23 | 只看该作者
开发工具也会慢慢的更专业,每个公司的可能不一样,但是zend studio是个大伙都会用的。
因胸联盟 该用户已被删除
15#
 楼主| 发表于 2015-4-26 04:08:59 | 只看该作者
首先声明:我是一个菜鸟,是一个初学者。学习了一段php后总是感觉自己没有提高,无奈。经过反思我认为我学习过程中存在很多问题,我改变了学习方法后自我感觉有了明显的进步。
兰色精灵 该用户已被删除
16#
发表于 2015-4-27 02:59:29 | 只看该作者
最后介绍一个代码出错,但是老找不到错误方法,就是 go to wc (囧),出去换换气没准回来就找到错误啦。
只想知道 该用户已被删除
17#
发表于 2015-5-4 10:57:32 | 只看该作者
我还是推荐用firefox ,配上firebug 插件调试js能省下不受时间。谷歌的浏览器最好也不少用,因为谷歌的大侠们实在是太天才啦,把一些原来的js代码加了一些特效。
爱飞 该用户已被删除
18#
发表于 2015-6-12 05:48:45 | 只看该作者
如果你可以写完像留言板这样的程序,那么你可以去一些别人的代码了,
再见西城 该用户已被删除
19#
发表于 2015-6-12 21:30:59 | 只看该作者
你很难利用原理去编写自己的代码。对于php来说,系统的学习我认为还是很重要的,当你有一定理解后,你可你针对某种效果研究,我想那时你不会只是复制代码的水平了。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2025-1-23 00:58

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表