background image

类的),在后面如果想要读取记录下来的字符串,只是需要用"转义符+记录的次序"来
读取。比如"1"就相当于第一个"[a-zA-Z0-9_-]+","2"相当于第二个([a-zA-Z0-9_-]+),"3"就
是第三个(.[a-zA-Z0-9_-])。但是在 PHP 中,""是一个特殊的字符,需要转义,所以""到了
PHP 的表达式中就应该写成"\1§"。
其他特殊符号:
"|":或符号"|"和 PHP 里面的或一样,不过是一个"|",而不是 PHP 的两个"||"!意思就是可
以是某个字符或者另一个字符串,比如"/abcd|dcba/"可能匹配"abcd"或者"dcba"。
贪婪模式
  前面在元字符中提到过"?"还有一个重要的作用,即"贪婪模式",什么是"贪婪模
式"呢?
  比如我们要匹配以字母 "a"开头字母"b"结尾的字符串,但是需要匹配的字符串
在"a"后面含有很多个"b",比如"a bbbbbbbbbbbbbbbbb",那正则表达式是会匹配第一
个"b"还是最后一个"b"呢?如果你使用了贪婪模式,那么会匹配到最后一个"b",反之只
是匹配到第一个"b"。
使用贪婪模式的表达式如下:
/a.+?b/
/a.+b/U
不使用贪婪模式的如下:
/a.+b/
上面使用了一个修饰符 U,详见下面的部分。
修饰符
  在正则表达式里面的修饰符可以改变正则的很多特性,使得正则表达式更加适合你
的需要(注意:修饰符对于大小写是敏感的,这意味着"e"并不等于"E")。正则表达式里
面的修饰符如下:
i :如果在修饰符中加上"i",则正则将会取消大小写敏感性,即"a"和"A" 是一样的。
m:默认的正则开始"^"和结束"$"只是对于正则字符串如果在修饰符中加上"m",那么开
始和结束将会指字符串的每一行:每一行的开头就是"^",结尾就是"$"。
s:如果在修饰符中加入"s",那么默认的"."代表除了换行符以外的任何字符将会变成任意
字符,也就是包括换行符!
x:如果加上该修饰符,表达式中的空白字符将会被忽略,除非它已经被转义。
e:本修饰符仅仅对于 replacement 有用,代表在 replacement 中作为 PHP 代码。
A : 如果 使用 这个 修饰 符, 那么 表达 式 必 须是 匹配 的字 符串 中的 开 头 部分 。比 如
说"/a/A"匹配"abcd"。
E:与"m"相反,如果使用这个修饰符,那么"$"将匹配绝对字符串的结尾,而不是换行符
前面,默认就打开了这个模式。
U:和问号的作用差不多,用于设置"贪婪模式"。
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,就会返