(参考)PHP编程技巧:看实例学正则表达式
- 格式:doc
- 大小:23.50 KB
- 文档页数:6
php中正则表达式中的特殊符号字符/意义:对于字符,通常表⽰按字⾯意义,指出接着的字符为特殊字符,不作解释。
例如:/b/匹配字符'b',通过在b 前⾯加⼀个反斜杠,也就是/b/,则该字符变成特殊字符,表⽰匹配⼀个单词的分界线。
或者:对于⼏个字符,通常说明是特殊的,指出紧接着的字符不是特殊的,⽽应该按字⾯解释。
例如:*是⼀个特殊字符,匹配任意个字符(包括0个字符);例如:/a*/意味匹配0个或多个a。
为了匹配字⾯上的*,在a前⾯加⼀个反斜杠;例如:/a*/匹配'a*'。
字符^意义:表⽰匹配的字符必须在最前边。
例如:/^A/不匹配"an A,"中的'A',但匹配"An A."中最前⾯的'A'。
字符$意义:与^类似,匹配最末的字符。
例如:/t$/不匹配"eater"中的't',但匹配"eat"中的't'。
字符*意义:匹配*前⾯的字符0次或n次。
例如:/bo*/匹配"A ghost booooed"中的'boooo'或"A bird warbled"中的'b',但不匹配"Agoat grunted"中的任何字符。
字符+意义:匹配+号前⾯的字符1次或n次。
等价于{1,}。
例如:/a+/匹配"candy"中的'a'和"caaaaaaandy."中的所有'a'。
字符?意义:匹配?前⾯的字符0次或1次。
例如:/e?le?/匹配"angel"中的'el'和"angle."中的'le'。
字符.意义:(⼩数点)匹配除换⾏符外的所有单个的字符。
匹配换行和空格正则表达式php
在PHP中,可以使用正则表达式来匹配换行符和空格。
换行符可以使用`\n`表示,空格可以使用`\s`表示。
下面是一个示例代码,演示如何使用正则表达式匹配换行符和空格:
```php
$pattern = '/\s\n/';
$string = "Hello\nWorld";
if (preg_match_all($pattern, $string, $matches)) {
// 匹配成功
$newString = str_replace($matches[0], '', $string);
echo $newString; // 输出 "HelloWorld"
} else {
// 匹配失败
echo "未找到匹配项";
}
```
在上面的示例中,我们使用`\s`和`\n`来匹配空格和换行符。
然后,使用
`preg_match_all()`函数进行匹配,并将匹配结果存储在`$matches`数组中。
最后,使用`str_replace()`函数将匹配到的空格和换行符替换为空字符串,
得到新的字符串。
请注意,这只是一个简单的示例,用于演示如何使用正则表达式匹配换行符和空格。
实际应用中,你可能需要根据具体的需求进行调整和扩展。
php正则表达式php正则表达式是一种用于从字符串中提取特定元素的技巧。
它使用称为表达式的规则系统来匹配字符串中的元素,并从中提取出满足条件的信息,是一个非常有用的工具。
PHP正则表达式可以用来检查和替换字符串中的特定文本块,或提取字符串中特定部分的信息。
正则表达式会以特殊的语法规则查看目的字符串,并根据所用的正则表达式语法,返回提取的信息。
PHP使用正则表达式语言来解析正则表达式,并剖析字符串中的文本块,从而可以提取出特定文本或搜索匹配字符串特定文本内容。
使用PHP正则表达式可以节省大量的时间和精力,它可以很容易地在字符串中找到所需的文本,或者替换字符串中特定文本。
正则表达式在PHP编程中广泛使用,被用于从字符串中获取需要的信息,验证表单输入的有效性,替换目标字符串,检查给定字符串是否包含特定字符串,以及搜索字符串中的特定字符串。
PHP一共提供了三个正则表达式函数,分别是preg_match()、preg_match_all()和preg_replace(),每个函数都是用来解析正则表达式的。
preg_match()函数用于匹配字符串中的模式,preg_match_all()函数用于匹配能够匹配所有字符串中模式的子字符串,而preg_replace()函数则用于替换字符串中的模式或所有模式。
除了这三个正则表达式函数,PHP还提供了一些正则表达式帮助函数。
例如preg_quote()函数,它可以将字符串中的非字母字符和空格转义(替换)为可用于正则表达式的可见字符,从而可以保证正则表达式语句能够正常工作。
此外,还有preg_grep()函数,它可以用于在字符串数组中进行搜索,从而返回匹配模式的索引数组,以及preg_split()函数,它可以将字符串拆分为数组,根据指定的模式进行拆分。
正则表达式是PHP编程中一个非常重要的工具,它可以通过PHP 函数对字符串进行搜索和替换,提取特定的文本块,以及检查字符串的有效性,使得PHP程序开发的效率大大提高。
PHP常⽤正则表达式PHP代码$str = preg_replace("/(<a.*?>)(.*?)(<\/a>)/", '\1<span class="link">\2</span>\3', $str);其中⽤了三个⼦模式(每个圆括号中内容为⼀个⼦模式),第⼀个是链接开始标签,第⼆个是链接⽂本,第三个是</a>然后第⼆个参数中\1、\2、\3就表⽰这三个部分,要替换成什么样⼦还不简单?获取页⾯中的所有链接地址的PHP函数下⾯这个⽤PHP写的函数,可以获取任意的字符串$string中的所有链接地址($string可以是从⼀个HTML页⾯⽂件直接读取出来的字符串),结果保存在⼀个数组中返回.该函数⾃动把电⼦邮件地址排除在外,⽽且返回的数组中不会有重复元素.function GetAllLink($string){$string = str_replace("\r","",$string);$string = str_replace("\n","",$string);$regex[url] = "((http|https|ftp|telnet|news):\/\/)?([a-z0-9_\-\/\.]+\.[][a-z0-9:;&#@=_~%\?\/\.\,\+\-]+)";$regex[email] = "([a-z0-9_\-]+)@([a-z0-9_\-]+\.[a-z0-9\-\._\-]+)";//去掉标签之间的⽂字$string = eregi_replace(">[^<>]+<","><", $string);//去掉JAVASCRIPT代码$string = eregi_replace("<!--.*//-->","", $string);//去掉⾮<a>的HTML标签$string = eregi_replace("<[^a][^<>]*>","", $string);//去掉EMAIL链接$string = eregi_replace("<a([ ]+)href=([\"']*)mailto:($regex[email])([\"']*)[^>]*>","", $string);//替换需要的⽹页链接$string = eregi_replace("<a([ ]+)href=([\"']*)($regex[url])([\"']*)[^>]*>","\\3\t", $string);$output[0] = strtok($string, "\t");while(($temp = strtok("\t"))){if($temp && !in_array($temp, $output))$output[++$i] = $temp;}return $output;}以下是以PHP的语法所写的⽰例验证字符串是否只含数字与英⽂,字符串长度并在4~16个字符之间<?php$str = 'a1234';if (preg_match("^[a-zA-Z0-9]{4,16}$", $str)) {echo "验证成功";} else {echo "验证失敗";}?>简易的台湾⾝分证字号验证<?php$str = 'a1234';if (preg_match("^(?:\d{15}|\d{18})$", $str)) {echo "验证成功";} else {echo "验证失敗";}>匹配中⽂字符的正则表达式: [\u4e00-\u9fa5]评注:匹配中⽂还真是个头疼的事,有了这个表达式就好办了匹配双字节字符(包括汉字在内):[^\x00-\xff]评注:可以⽤来计算字符串的长度(⼀个双字节字符长度计2,ASCII字符计1)匹配空⽩⾏的正则表达式:\n\s*\r评注:可以⽤来删除空⽩⾏匹配HTML标记的正则表达式:<(\S*?)[^>]*>.*?</\1>|<.*? />评注:⽹上流传的版本太糟糕,上⾯这个也仅仅能匹配部分,对于复杂的嵌套标记依旧⽆能为⼒匹配⾸尾空⽩字符的正则表达式:^\s*|\s*$评注:可以⽤来删除⾏⾸⾏尾的空⽩字符(包括空格、制表符、换页符等等),⾮常有⽤的表达式匹配Email地址的正则表达式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*评注:表单验证时很实⽤匹配⽹址URL的正则表达式:[a-zA-z]+://[^\s]*评注:⽹上流传的版本功能很有限,上⾯这个基本可以满⾜需求匹配帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$ 评注:表单验证时很实⽤匹配国内电话号码:\d{3}-\d{8}|\d{4}-\d{7}评注:匹配形式如 0511-******* 或 021-********匹配腾讯QQ号:[1-9][0-9]{4,}评注:腾讯QQ号从10000开始匹配中国邮政编码:[1-9]\d{5}(?!\d)评注:中国邮政编码为6位数字匹配⾝份证:\d{15}|\d{18}评注:中国的⾝份证为15位或18位匹配ip地址:\d+\.\d+\.\d+\.\d+评注:提取ip地址时有⽤匹配特定数字:^[1-9]\d*$ //匹配正整数^-[1-9]\d*$ //匹配负整数^-?[1-9]\d*$ //匹配整数^[1-9]\d*|0$ //匹配⾮负整数(正整数 + 0)^-[1-9]\d*|0$ //匹配⾮正整数(负整数 + 0)^[1-9]\d*\.\d*|0\.\d*[1-9]\d*$ //匹配正浮点数^-([1-9]\d*\.\d*|0\.\d*[1-9]\d*)$ //匹配负浮点数^-?([1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0)$ //匹配浮点数^[1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0$ //匹配⾮负浮点数(正浮点数 + 0)^(-([1-9]\d*\.\d*|0\.\d*[1-9]\d*))|0?\.0+|0$ //匹配⾮正浮点数(负浮点数 + 0)评注:处理⼤量数据时有⽤,具体应⽤时注意修正匹配特定字符串:^[A-Za-z]+$ //匹配由26个英⽂字母组成的字符串^[A-Z]+$ //匹配由26个英⽂字母的⼤写组成的字符串^[a-z]+$ //匹配由26个英⽂字母的⼩写组成的字符串^[A-Za-z0-9]+$ //匹配由数字和26个英⽂字母组成的字符串^\w+$ //匹配由数字、26个英⽂字母或者下划线组成的字符串下⾯是⼀些特殊字符:正则表达式中的特殊字符:(学习参考书-<<精通正则表达式>>)字符意义:对于字符,通常表⽰按字⾯意义,指出接着的字符为特殊字符,不作解释。
正则表达式整理邹义良邮箱:it9981@微博:/it266论坛:定义:是指一个用来描述或者匹配一系列符合某个句法规则的字符串的单个字符串。
使用原则:可以使用字符串函数完成的功能,优先选择函数,复杂的操作,才选用正则表过式。
需要和函数一起使用,才能发挥出正则表达式的作用。
(分割、匹配、查找、替换…)php中提供两套正则表达式函数库:1.POSIX扩展正则表达式函数(ereg_开头)2.Perl兼容正则表达式函数(preg_开头) 推荐学习和使用正则表达式模式如何编写语法:1.定界符号2.原子3.元字符4.模式修正符号测试代码<?php$regex='/[^0-9a-zA-Z]/';$str='1aA#';echo '表达式:<b>'.$regex.'</b> ';echo '字符串:<b>'.$str.'</b> ';if(preg_match($regex,$str)){echo '<font color="green">匹配成功</font>';}else{echo '<font color="red">匹配失败</font>';}?>定界符:起始和结束的符号。
除了字母、数字和反斜线(\)以外的任何字符,都可以为定界符。
// || {} !! ……没有特殊需要,都使用//作为定界符定界符之间,是原子、元字符,字界符外边,是模式修正符。
有的语言中,可以没有定界符原子:是正则表达式的最基本组成单位,必须至少包含一个原子。
只要在正则表达式中,可以单独使用的字符,都是原子。
正则表达式详解正则表达式1.什么是正则表达式简单的说,正则表达式是一种可以用于文字模式匹配和替换的强有力的工具。
是由一系列普通字符和特殊字符组成的能明确描述文本字符串的文字匹配模式。
正则表达式并非一门专用语言,但也可以看作是一种语言,它可以让用户通过使用一系列普通字符和特殊字符构建能明确描述文本字符串的匹配模式。
除了简单描述这些模式之外,正则表达式解释引擎通常可用于遍历匹配,并使用模式作为分隔符来将字符串解析为子字符串,或以智能方式替换文本或重新设置文本格式。
正则表达式为解决与文本处理有关的许多常见任务提供了有效而简捷的方式。
正则表达式具有两种标准:·基本的正则表达式(BRE –Basic Regular Expressions)·扩展的正则表达式(ERE – Extended Regular Expressions)。
ERE包括BRE功能和另外其它的概念。
正则表达式目前有两种解释引擎:·基于字符驱动(text-directed engine)·基于正则表达式驱动(regex-directed engine)Jeffery Friedl把它们称作DFA和NFA解释引擎。
约定:为了描述起来方便,在本文中做一些约定:1.本文所举例的所有表达时都是基于NFA解释引擎的。
2.正则表达式,也就是匹配模式,会简写为Regex。
3. Regex的匹配目标,也就是目标字符串,会简写为String。
4.匹配结果用会用黄色底色标识。
5.用1\+1=2 括起来的表示这是一个regex。
6.举例会用以下格式:testThis is a test会匹配test,testcase等2.正则表达式的起源正则表达式的”祖先”可以一直上溯至对人类神经系统如何工作的早期研究。
Warren McCulloch 和 Walter Pitts 这两位神经生理学家研究出一种数学方式来描述这些神经网络。
php正则:匹配(),{},[]⼩括号,⼤括号,中括号⾥⾯的内容php正则:匹配(),{},[]⼩括号,⼤括号,中括号⾥⾯的内容⽐如有⼀段字符:$s='60c8{"code":"200","message":"success","data":[{"_id":"780521","time":1476768196,"position":{"long":108.90415,"lat":35.25623},"speed":495.677952,"anum":"B6552","atype":"A321","atypename":"Airbus A321-231","angle":"198","vspeed":"-576","devic 我要匹配,{}括号⾥⾯的内容,单独拿出来。
preg_match('/(?:\{)(.*)(?:\})/i', $s, $match);var_dump($match);说明:PHP使⽤正则表达式提取字符串中尖括号<>、⼩括号()、中括号[]、⼤括号{}中的字符⽰例,需要的朋友可以参考下$str="你好<我>(爱)[北京]{天安门}";echo f1($str); //返回你好echo f2($str); //返回我echo f3($str); //返回爱echo f4($str); //返回北京echo f5($str); //返回天安门function f1($str){$result = array();preg_match_all("/^(.*)(?:<)/i",$str, $result);return $result[1][0];}function f2($str){$result = array();preg_match_all("/(?:<)(.*)(?:>)/i",$str, $result);return $result[1][0];}function f3($str){$result = array();preg_match_all("/(?:\()(.*)(?:\))/i",$str, $result);return $result[1][0];}function f4($str){$result = array();preg_match_all("/(?:\[)(.*)(?:\])/i",$str, $result);return $result[1][0];}function f5($str){$result = array();preg_match_all("/(?:\{)(.*)(?:\})/i",$str, $result);return $result[1][0];}PS: (?:字符) 表⽰不捕获这个字符。
正则表达式语法正则表达式是一种文本模式,包括普通字符(例如,a 到z 之间的字母)和特殊字符(称为“元字符”)。
模式描述在搜索文本时要匹配的一个或多个字符串。
正则表达式示例下表包含了元字符的完整列表以及它们在正则表达式上下文中的行为:优先级顺序正则表达式从左到右进行计算,并遵循优先级顺序,这与算术表达式非常类似。
运算符下表从最高到最低说明了各种正则表达式运算符的优先级顺序:字符具有高于替换运算符的优先级,使得“m|food”匹配“m”或“food”。
若要匹配“mood”或“food”,请使用括号创建子表达式,从而产生“(m|f)ood”。
特殊字符许多元字符要求在试图匹配它们时特别对待。
若要匹配这些特殊字符,必须首先使字符“转义”,即,将反斜杠字符(\) 放在它们前面。
下表列出了特殊字符以及它们的含义:特殊字符表不可打印字符非打印字符也可以是正则表达式的组成部分。
下表列出了表示非打印字符的转义序列:转义序列字符匹配句点(.) 匹配字符串中的各种打印或非打印字符,只有一个字符例外。
这个例外就是换行符(\n)。
下面的正则表达式匹配aac、abc、acc、adc等等,以及a1c、a2c、a-c 和a#c:/a.c/若要匹配包含文件名的字符串,而句点(.) 是输入字符串的组成部分,请在正则表达式中的句点前面加反斜扛(\) 字符。
举例来说明,下面的正则表达式匹配filename.ext:/filename\.ext/这些表达式只让您匹配“任何”单个字符。
可能需要匹配列表中的特定字符组。
例如,可能需要查找用数字表示的章节标题(Chapter 1、Chapter 2 等等)。
中括号表达式若要创建匹配字符组的一个列表,请在方括号([ 和])内放置一个或更多单个字符。
当字符括在中括号内时,该列表称为“中括号表达式”。
与在任何别的位置一样,普通字符在中括号内表示其本身,即,它在输入文本中匹配一次其本身。
大多数特殊字符在中括号表达式内出现时失去它们的意义。
最重要的是——请给我30分钟,如果你没有使用正则表达式的经验,请不要试图在30秒内入门——除非你是超人 :)别被下面那些复杂的表达式吓倒,只要跟着我一步一步来,你会发现正则表达式其实并没有你想像中的那么困难。
当然,如果你看完了这篇教程之后,发现自己明白了很多,却又几乎什么都记不得,那也是很正常的——我认为,没接触过正则表达式的人在看完这篇教程后,能把提到过的语法记住80%以上的可能性为零。
这里只是让你明白基本的原理,以后你还需要多练习,多使用,才能熟练掌握正则表达式。
除了作为入门教程之外,本文还试图成为可以在日常工作中使用的正则表达式语法参考手册。
就作者本人的经历来说,这个目标还是完成得不错的——你看,我自己也没能把所有的东西记下来,不是吗?清除格式文本格式约定:专业术语元字符/语法格式正则表达式正则表达式中的一部分(用于分析)对其进行匹配的源字符串对正则表达式或其中一部分的说明隐藏边注本文右边有一些注释,主要是用来提供一些相关信息,或者给没有程序员背景的读者解释一些基本概念,通常可以忽略。
在编写处理字符串的程序或网页时,经常会有查找符合某些复杂规则的字符串的需要。
正则表达式就是用于描述这些规则的工具。
换句话说,正则表达式就是记录文本规则的代码。
很可能你使用过Windows/Dos下用于文件查找的通配符(wildcard),也就是*和?。
如果你想查找某个目录下的所有的Word文档的话,你会搜索*.doc。
在这里,*会被解释成任意的字符串。
和通配符类似,正则表达式也是用来进行文本匹配的工具,只不过比起通配符,它能更精确地描述你的需求——当然,代价就是更复杂——比如你可以编写一个正则表达式,用来查找所有以0开头,后面跟着2-3个数字,然后是一个连字号“-”,最后是7或8位数字的字符串(像或)。
学习正则表达式的最好方法是从例子开始,理解例子之后再自己对例子进行修改,实验。
下面给出了不少简单的例子,并对它们作了详细的说明。
首先,让我们看看两个特别的字符:’^’ 和‘$’ 他们是分别用来匹配字符串的开始和结束,一下分别举例说明:"^The": 匹配以"The"开头的字符串;"of despair$": 匹配以"of despair" 结尾的字符串;"^abc$": 匹配以abc开头和以abc结尾的字符串,实际上是只有abc与之匹配;"notice": 匹配包含notice的字符串;你可以看见如果你没有用我们提到的两个字符(最后一个例子),就是说模式(正则表达式)可以出现在被检验字符串的任何地方,你没有把他锁定到两边。
这里还有几个字符'*', '+',和'?', 他们用来表示一个字符可以出现的次数或者顺序. 他们分别表示:"zero or more", "one or more", and "zero or one." 这里是一些例子: "ab*": 匹配字符串a和0个或者更多b组成的字符串("a", "ab", "abbb", etc.);"ab+": 和上面一样,但最少有一个b ("ab", "abbb", etc.);"ab?":匹配0个或者一个b;"a?b+$": 匹配以一个或者0个a再加上一个以上的b结尾的字符串.你也可以在大括号里面限制字符出现的个数,比如"ab{2}": 匹配一个a后面跟两个b(一个也不能少)("abb");"ab{2,}": 最少更两个b("abb", "abbbb", etc.);"ab{3,5}": 2-5个b("abbb", "abbbb", or "abbbbb").你还要注意到你必须总是指定(i.e, "{0,2}", not "{,2}").同样,你必须注意到, '*', '+', 和'?' 分别和一下三个范围标注是一样的,"{0,}", "{1,}", 和"{0,1}"。
现在把一定数量的字符放到小括号里,比如:"a(bc)*": 匹配a 后面跟0个或者一个"bc";"a(bc){1,5}": 一个到5个"bc."还有一个字符'│', 相当于OR 操作:"hi│hello": 匹配含有"hi" 或者"hello" 的字符串;"(b│cd)ef": 匹配含有"bef" 或者"cdef"的字符串;"(a│b)*c": 匹配含有这样- 多个(包括0个)a或b,后面跟一个c的字符串的字符串;一个点('.')可以代表所有的单一字符:"a.[0-9]": 一个a跟一个字符再跟一个数字的(含有这样一个字符串的字符串将被匹配,以后省略此括号)"^.{3}$": 以三个字符结尾.中括号括住的内容只匹配一个单一的字符"[ab]": 匹配单个的a 或者b ( 和"a│b" 一样);"[a-d]": 匹配'a' 到'd'的单个字符(和"a│b│c│d" 还有"[abcd]"效果一样);"^[a-zA-Z]": 匹配以字母开头的字符串"[0-9]%": 匹配含有形如x%的字符串",[a-zA-Z0-9]$": 匹配以逗号在加一个数字或字母结尾的字符串你也可以把你不想要得字符列在中括号里,你只需要在总括号里面使用'^' 作为开头(i.e., "%[^a-zA-Z]%" 匹配含有两个百分号里面有一个非字母的字符串).为了能够解释,但"^.[$()│*+?{"作为有特殊意义的字符的时候,你必须在这些字符面前加'', 还有在php3中你应该避免在模式的最前面使用, 比如说,正则表达式"($│?[0-9]+" 应该这样调用ereg("(\$│?[0-9]+", $str) (不知道php4是不是一样)不要忘记在中括号里面的字符是这条规路的例外—在中括号里面, 所有的特殊字符,包括(''), 都将失去他们的特殊性质(i.e., "[*+?{}.]"匹配含有这些字符的字符串). 还有,正如regx 的手册告诉我们: "如果列表里含有']', 最好把它作为列表里的第一个字符(可能跟在'^'后面). 如果含有'-', 最好把它放在最前面或者最后面, or 或者一个范围的第二个结束点(i.e. [a-d-0-9]中间的‘-’将有效.为了完整, 我应该涉及到collating sequences, character classes, 同埋equivalenc e classes. 但我在这些方面不想讲的太详细, 这些在下面的文章仲都不需要涉及到. 你们可以在regex man pages 那里得到更多消息.如何构建一个模式来匹配货币数量的输入好了,现在我们要用我们所学的来干一些有用的事:构建一个匹配模式去检查输入的信息是否为一个表示money的数字。
我们认为一个表示money的数量有四种方式:"10000. 00" 和"10,000.00",或者没有小数部分, "10000" and "10,000". 现在让我们开始构建这个匹配模式:^[1-9][0-9]*$这是所变量必须以非0的数字开头.但这也意味着单一的"0" 也不能通过测试. 以下是解决的方法:^(0│[1-9][0-9]*)$"只有0和不以0开头的数字与之匹配",我们也可以允许一个负号再数字之前:^(0│-?[1-9][0-9]*)$这就是: "0 或者一个以0开头可能有一个负号在前面的数字." 好了, 好了现在让我们别那么严谨,允许以0开头.现在让我们放弃负号, 因为我们在表示钱币的时候并不需要用到. 我们现在指定模式用来匹配小数部分^[0-9]+(.[0-9]+)?$这暗示匹配的字符串必须最少以一个阿拉伯数字开头. 但是注意,在上面模式中"10." 是不匹配的, 只有"10" 和"10.2" 才可以. (你知道为什么吗)^[0-9]+(.[0-9]{2})?$我们上面指定小数点后面必须有两位小数.如果你认为这样太苛刻,你可以改成:^[0-9]+(.[0-9]{1,2})?$这将允许小数点后面有一到两个字符. 现在我们加上用来增加可读性的逗号(每隔三位), 我们可以这样表示:^[0-9]{1,3}(,[0-9]{3})*(.[0-9]{1,2})?$不要忘记加号'+' 可以被乘号'*' 替代如果你想允许空白字符串被输入话(为什么?). 也不要忘记反斜杆’’ 在php字符串中可能会出现错误(很普遍的错误). 现在,我们已经可以确认字符串了, 我们现在把所有逗号都去掉str_replace(",", "", $money) 然后在把类型看成double然后我们就可以通过他做数学计算了.构造检查email的正则表达式让我们继续讨论怎么验证一个email地址. 在一个完整的email地址中有三个部分: PO P3 用户名(在'@' 左边的一切), '@', 服务器名(就是剩下那部分). 用户名可以含有大小写字母阿拉伯数字,句号('.'), 减号('-'), and 下划线('_'). 服务器名字也是符合这个规则,当然下划线除外.现在, 用户名的开始和结束都不能是句点. 服务器也是这样. 还有你不能有两个连续的句点他们之间至少存在一个字符,好现在我们来看一下怎么为用户名写一个匹配模式: ^[_a-zA-Z0-9-]+$现在还不能允许句号的存在. 我们把它加上:^[_a-zA-Z0-9-]+(.[_a-zA-Z0-9-]+)*$上面的意思就是说: "以至少一个规范字符(除.意外)开头,后面跟着0个或者多个以点开始的字符串."简单化一点, 我们可以用eregi()取代ereg().eregi()对大小写不敏感, 我们就不需要指定两个范围"a-z" 和"A-Z" –只需要指定一个就可以了:^[_a-z0-9-]+(.[_a-z0-9-]+)*$后面的服务器名字也是一样,但要去掉下划线:^[a-z0-9-]+(.[a-z0-9-]+)*$Done. 现在只需要用”@”把两部分连接:^[_a-z0-9-]+(.[_a-z0-9-]+)*@[a-z0-9-]+(.[a-z0-9-]+)*$这就是完整的email认证匹配模式了,只需要调用eregi(‘^[_a-z0-9-]+(.[_a-z0-9-]+)*@[a-z0-9-]+(.[a-z0-9-]+)*$ ’,$eamil)就可以得到是否为email了。
正则表达式的其他用法提取字符串ereg() and eregi() 有一个特性是允许用户通过正则表达式去提取字符串的一部分(具体用法你可以阅读手册). 比如说,我们想从path/URL 提取文件名–下面的代码就是你需要:ereg("([^\/]*)$", $pathOrUrl, $regs);echo $regs[1];高级的代换ereg_replace() 和eregi_replace()也是非常有用的: 假如我们想把所有的间隔负号都替换成逗号:ereg_replace("[ ]+", ",", trim($str));(注:文档可能无法思考全面,请浏览后下载,供参考。