PHP正则表达式基本函数 修饰符 元字符和需转义字符说明

我在写小偷中用了大量的正则,所以在接下来的版本中要逐步减少正则的应用

在PHP正则表达式中需要转义的字符如下:

$^*()+={}[]|/:<>.?'"

注意:perl风格中表达式要求以/开始和结尾,如:/food/ 表匹配字符 food

perl修饰符如下:

i 完成不区分大小写的搜索

g 查找所有出现(all occurrences,完成全局搜索)

m 将一个字符串视为多行(m就表示多(multiple))。默认情况下,^和$字符匹配字符串中的最开始和最末尾。使用m修饰符将使^和$匹配字符串中每行的开始

s 将一个字符串视为一行,忽略其中的所有换行符;它与m修饰符正好相反

x 忽略正则表达式中的空白和注释

U 第一次匹配后停止。默认情况下,将找到最后一个匹配字符结果。利用这个修饰符可以在第一次匹配后停止。进而形式循环匹配。

元字符说明:

利用Perl正则表达式还可以做另一件有用的事情,这就是使用各种元字符来搜索匹配。元字符(metacharacter)就是一个前面有反斜线的字母字符,表示某种特殊含义。以下是一些有用的元字符。

A 只匹配字符串开头

b 匹配单词边界

B 匹配单词边界之外的任意字符

d 匹配数字字符,它与[0-9]相同

D 匹配非数字字符

s 匹配空白字符

S 匹配非空白字符

[] 包围一个字符类,字符类包括:[0-9] [a-z] [a-zA-Z] 等类似。

() 包围一个字符分组或定义一个反引用

$ 匹配行尾

^ 匹配行首

* 匹配前面的子表达式零次或多次。要匹配 * 字符,请使用 *

+ 匹配前面的子表达式一次或多次。要匹配 + 字符,请使用 +

? 匹配前面的子表达式零次或一次,或指明一个非贪婪限定符 ?

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

引出下一个元字符

w 匹配任何只包含下划线和字母数字字符的字符串,它与 [a-zA-Z0-9_]相同

W 匹配没有下划线和字母数字字符的字符串

Perl风格函数有:

array preg_grep(string pattern, array input [, flags])

搜索数组中所有元素,返回由与某个模式匹配的所有元素组成的数组

PHP 4.3增加了一个可选参数 flag,它接受一个值 PREG_GREP_INVERT 传递此标志将得到与该模式不匹配的数据元素。

int preg_match(string pattern, string string [, array matches [, int flags [, int offset]]])

在字符串中搜索模式,如果存在返回TRUE,否则返回FALSE。

可选输入参数matches可以包含搜索模式中包含的子模式的各个部分。默认返回 匹配的字符串,当有()子包围时,会在数组后面输出。

int preg_match_all(string pattern, string string, array pattern_array [, int order])

和函数 preg_match一样,不过 preg_match 只搜索一次,而 preg_match_all 会执行循环搜索,返回所有匹配的结果。

mixed preg_replace(mixed pattern, mixed replacement, mixed str [, int limit])

用replacement替换pattern的所有出现,并返回修改后的结果。

可选 limit 指定应当发生多少次匹配。不设置limit或设置为-1将替换所有出现的情况。

以上为常用函数,还有 preg_quote, preg_replace_callbak, preg_split等详细解释略。。。

时间: 2024-11-03 21:12:04

PHP正则表达式基本函数 修饰符 元字符和需转义字符说明的相关文章

正则表达式基本函数 修饰符 元字符和需转义字

在php教程正则表达式中需要转义的字符如下: $^*()+={}[]|/:<>.?'" 注意:perl风格中表达式要求以/开始和结尾,如:/food/ 表匹配字符 food perl修饰符如下: i 完成不区分大小写的搜索 g 查找所有出现(all occurrences,完成全局搜索) m 将一个字符串视为多行(m就表示多(multiple)).默认情况下,^和$字符匹配字符串中的最开始和最末尾.使用m修饰符将使^和$匹配字符串中每行的开始 s 将一个字符串视为一行,忽略其中的所有

php正则表达式基本函数修饰符元字符和需转义字

在php教程正则表达式中需要转义的字符如下: $^*()+={}[]|/:<>.?'" 注意:perl风格中表达式要求以/开始和结尾,如:/food/ 表匹配字符 food perl修饰符如下: i 完成不区分大小写的搜索 g 查找所有出现(all occurrences,完成全局搜索) m 将一个字符串视为多行(m就表示多(multiple)).默认情况下,^和$字符匹配字符串中的最开始和最末尾.使用m修饰符将使^和$匹配字符串中每行的开始 s 将一个字符串视为一行,忽略其中的所有

正则表达式u修饰符(支持UTF-16编码)

正则表达式u修饰符: 此修饰符标识能够正确处理大于\uFFFF的Unicode字符. 也就是说,会正确处理四个字节的UTF-16编码. 此修饰符是ES2015新增,更多正则表达式新特性可以参阅ES2015 正则表达式新增特性一章节. 更多正则表达式教程可以参阅正则表达式教程板块. 代码实例: console.log(/^\uD842/u.test("\uD842\uDFB7")) 输出false,由于"\uD842\uDFB7"是一个四个字节的UTF-16编码,代表

正则表达式m修饰符(多行匹配)

正则表达式m修饰符: m修饰符规定正则表达式可以执行多行匹配. m修饰符的作用是修改^和$在正则表达式中的作用,让它们分别表示行首和行尾. 在默认状态下,一个字符串无论是否换行只有一个开始^和结尾$,如果采用多行匹配,那么每一个行都有一个^和结尾$. 语法结构: 构造函数方式: new RegExp("regexp","m") 对象直接量方式: /regexp/m 浏览器支持: IE浏览器支持此元字符. 火狐浏览器支持此元字符. 谷歌浏览器支持此元字符. 实例代码:

正则表达式i修饰符(大小写不敏感)

正则表达式i修饰符: i修饰符用来规定正则表达式的匹配是大小写不敏感的. 语法结构: 构造函数方式: new RegExp("regexp","i") 对象直接量方式: /regexp/i 浏览器支持: IE浏览器支持此元字符. 火狐浏览器支持此元字符. 谷歌浏览器支持此元字符. 实例代码: var str="This is an antzone good"; var reg=/this/; console.log(str.match(reg))

浅谈PHP正则表达式中修饰符/i, /is, /s, /isU_php技巧

在学习PHP正则表达式修饰符之前先来理解下贪婪模式,前面在元字符中提到过"?"还有一个重要的作用,即"贪婪模式",什么是"贪婪模式"呢? PHP正则表达式贪婪模式: 比如我们要匹配以字母"a"开头字母"b"结尾的字符串,但是需要匹配的字符串在"a"后面含有很多个"b",比如"a bbbbbbbbbbbbbbbbb",那正则表达式是会匹配第一个&qu

PHP中正则表达式模式修饰符详解

PHP模式修饰符又叫模式修正符,是在正则表达式的定界符之外使用.主要用来调整正则表达式的解释,提扩展了正则表达式在匹配.替换等操作的某些功能,增强了正则的能力.但是有很多地方的解释都是错误的,也容易误导别人,所以今天我把这个文档整理出来,供大家参考. 模式修正符号 功能描述 i 在和正则匹配是不区分大小写 m 将字符串视为多行.默认的正则开始"^"和结束"$"将目标字条串作为一单一的一"行"字符(甚至其中包括换行符也是如此).如果在修饰符中加上&

PHP正则表达式模式修饰符详解

PHP模式修饰符又叫模式修正符,是在正则表达式的定界符之外使用.主要用来调整正则表达式的解释,提扩展了正则表达式在匹配.替换等操作的某些功能,增强了正则的能力.但是有很多地方的解释都是错误的,也容易误导别人,所以今天我把这个文档整理出来,供大家参考. 模式修正符号 功能描述 i 在和正则匹配是不区分大小写 m 将字符串视为多行.默认的正则开始"^"和结束"$"将目标字条串作为一单一的一"行"字符(甚至其中包括换行符也是如此).如果在修饰符中加上&

正则表达式模式修饰符

i (PCRE_CASELESS) 如果设置了这个修饰符,模式中的字母会进行大小写不敏感匹配. m (PCRE_MULTILINE) 默认情况下,PCRE 认为目标字符串是由单行字符组成的(然而实际上它可能会包含多行), "行首"元字符 (^) 仅匹配字符串的开始位置, 而"行末"元字符 ($) 仅匹配字符串末尾, 或者最后的换行符(除非设置了 D 修饰符).这个行为和 perl 相同. 当这个修饰符设置之后,"行首"和"行末"