- 1、本文档共44页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
PHPChina - 8PHP正则表达式
PHP正则表达式 高洛峰 正则表达式 基础知识 字符集 POSIX 扩展正则表达式函数 Perl 兼容正则表达式函数 正则表达式简介(一) 正则表达式是用于描述字符排列模式一种语法规则。它主要用于字符串的模式分割、匹配、查找及替换操作。到目前为止,我们前面所用过的精确(文本)匹配也是一种正则表达式。 在PHP中,正则表达式一般是由正规字符和一些特殊字符(类似于通配符)联合构成的一个文本模式的程序性描述。 在程序语言中,通常将模式表达式(即正则表达式)包含在两个反斜线“/”之间,如“/apple/”。用户只要把需要匹配的模式内容放入定界之间即可。作为定界的字符也不仅仅局限于“/”。除了字母、数字和斜线“\”以外的任何字符都可以作为定界符,像“#”、“/”、“!”等都可以的。 如果使用一个没有特殊字符的正则表达式,相当于纯文本有哪些信誉好的足球投注网站,使用strstr( )函数也可达到同样的效果。 正则表达式简介(二) 在PHP中有两套正则表达式函数库,两者功能相似,只是执行效率略有差异: 一套是由PCRE(Perl Compatible Regular Expression)库提供的。使用“preg_”为前缀命名的函数; 一套由POSIX(Portable Operation System interface)扩展提供的。使用以“ereg_”为前缀命名的函数; 使用正则表达式的原因之一,是在典型的有哪些信誉好的足球投注网站和替换操作中,只能对确切文字进行匹配,对象动态文本的有哪些信誉好的足球投注网站就有困难了,甚至是不可能的。 /^-?\d+$|^-?0[xX][\da-fA-F]+$/ /^[0-9a-zA-Z_-]+@[0-9a-zA-Z_-]+(\.[0-9a-zA-Z_-]+){0,3}]$/ 正则表达式较重要和较有用的角色是验证用户数据的有效性检查。PHP中,正则表达式有三个作用: 匹配,也常常用于从字符串中析取信息。 用新文本代替匹配文本。 将一个字符串拆分为一组更小的信息块。 正则表达式的语法规则 正则表达式是主要由: 原子(普通字符,如英文字符) 元字符(有特殊功用的字符) 以及模式修正字符组成。 一个正则表达式中至少包含一个原子。 原子(Atom) 原子是组成正则表达式的基本单位,在分析正则表达式时,应作为一个整体。 原子字符是由所有末显式指定为元字符的打印和非打印字符组成。这包括所有的英文字母、数字、标点符号以及其他一些符号。原子也包括以下内容。 单个字符、数字,如a~z,A~Z,0~9. 模式单元,如(ABC).可以理解为由多个原子组成的大的原子。 原子表,如[ABC]. 重新使用的模式单元。 普通转义字符。 转义元字符。 正则表达式所使用的普通转义字符 原子 说明 -------------------------------------------------------------------------------------------------------- \d 匹配一个数字;等价于[0-9] \D 匹配除数字以外任何一个字符;等价于[^0-9] \w 匹配一个英文字母、数字或下划线;等价于[0-9a-zA-Z_] \W 匹配除英文字母、数字和下划线以外任何一个字符;等价于[^0-9a-zA-Z_] \s 匹配一个空白字符;等价于[\f\n\r\t\v] \S 匹配除空白字符以外任何一个字符;等价于[^\f\n\r\t\v] \f 匹配一个换页符等价于 \x0c 或 \cL \n 匹配一个换行符;等价于 \x0a 或 \cJ \r 匹配一个回车符等价于\x0d 或 \cM \t 匹配一个制表符;等价于 \x09\或\cl \v 匹配一个垂直制表符;等价于\x0b或\ck \oNN 匹配一个八进制数字 \xNN 匹配一个十六进制数字 \cC 匹配一个控制字符 元字符(Meta-character) 元字符是用于构造规则表达式的具有特殊含义的字符。如果要在正则表达式中包含元字符本身,必须在其前加上”\”进行转义 说明 元字符 * 0次、1次或多次匹配其前的原子 + 1次或多次匹配其前的原子 ? 0次或1次匹配其前的原子 . 匹配任何一个字符 | 匹配两个或多个选择 ^或\A 匹配字符串串首的原子 $或\Z 匹配字符串串尾的原子 \b 匹配单词的边界 \B 匹配除单词边界以外的部分 [] 匹配方括号中的任一原子 [^] 匹配除方括号中的原子外的任何字符 () 整体表示一个原子 {m} 表示其前原子恰好出现m次 {m,n} 表示其前原子至少出现m次,至多出现n次(nm) {m,} 表示其前原子出现不少于m次
文档评论(0)