php 正则字符汇总
2016-01-19 09:51
465 查看
日常工作中经常需要用到正则,每次去查都比较麻烦,自己整理了一份,只能说包含大部分,如果有漏掉的希望大家给予补充,谢谢!!!
首先, 正则中部分字符需要用反斜杠(\)进行转移 $^*()+={}[]|/:<>.?'"
下面开始介绍主要的字符
1、定界符
除了字母、数字和反斜线\以外的任何字符都可以为定界符号,比如 | |、//、{}、!!等等,但是需要注意,如果没有特殊需要,我们都使用正斜线//作为正则表达式的定界符号。
2、原子
1)系统提供的
\d 表示任意一个十进制的数字 [0-9]
\D 表示任意一个除数字这外的字符 [^0-9]
\s 表示任意一个空白字符,空格、\n\r\t\f [\n\r\t\f ]
\S 表示任意一个非空白 [^\n\r\t\f ]
\w 表示任意一个字 a-zA-Z0-9_ [a-zA-Z0-9_]
\W 表示任意一个非字,除了a-zA-Z0-9_以外的任意一个字符 [^a-zA-Z0-9_]
2)自定义的 []
比如 [0-9]
注意: 上面用到两个符号:
- 表示范围 如 [0-9] 表示从0到9 [a-z] 表示字母从a-z
^ 表示非 取反 [^0-9] 表示除了0到9以外的字符
3、元字符
A 只匹配字符串开头
b 匹配单词边界
B 匹配单词边界之外的任意字符
d 匹配数字字符,它与[0-9]相同
D 匹配非数字字符
s 匹配空白字符
S 匹配非空白字符
[] 包围一个字符类,字符类包括:[0-9] [a-z] [a-zA-Z] 等类似。
() 包围一个字符分组或定义一个反引用
{} 大括号用来精确指定匹配元字符出现的次数
$ 匹配行尾
^ 匹配行首
* 匹配前面的子表达式零次或多次。要匹配 * 字符,请使用 *
+ 匹配前面的子表达式一次或多次。要匹配 + 字符,请使用 +
? 匹配前面的子表达式零次或一次,或指明一个非贪婪限定符 ?
. 匹配除换行之外的任何字符
引出下一个元字符
w 匹配任何只包含下划线和字母数字字符的字符串,它与 [a-zA-Z0-9_]相同
W 匹配没有下划线和字母数字字符的字符串
4、模式修正符
i 完成不区分大小写的搜索
g 查找所有出现(all occurrences,完成全局搜索)
m 将一个字符串视为多行(m就表示多(multiple))。默认情况下,^和$字符匹配字符串中的最开始和最末尾。使用m修饰符将使^和$匹配字符串中每行的开始
s 将一个字符串视为一行,忽略其中的所有换行符;它与m修饰符正好相反
x 忽略正则表达式中的空白和注释
U 第一次匹配后停止。默认情况下,将找到最后一个匹配字符结果。利用这个修饰符可以在第一次匹配后停止。进而形式循环匹配
u (PCRE_UTF8) 此修正符启用了一个 PCRE 中与 Perl 不兼容的额外功能。模式字符串被当成 UTF-8。本修正符在 Unix 下自 PHP 4.1.0 起可用,在 win32 下自 PHP 4.2.3 起可用。
以上就是我汇总的了,有问题及时联系,只是我个人理解,并非权威
首先, 正则中部分字符需要用反斜杠(\)进行转移 $^*()+={}[]|/:<>.?'"
下面开始介绍主要的字符
1、定界符
除了字母、数字和反斜线\以外的任何字符都可以为定界符号,比如 | |、//、{}、!!等等,但是需要注意,如果没有特殊需要,我们都使用正斜线//作为正则表达式的定界符号。
2、原子
1)系统提供的
\d 表示任意一个十进制的数字 [0-9]
\D 表示任意一个除数字这外的字符 [^0-9]
\s 表示任意一个空白字符,空格、\n\r\t\f [\n\r\t\f ]
\S 表示任意一个非空白 [^\n\r\t\f ]
\w 表示任意一个字 a-zA-Z0-9_ [a-zA-Z0-9_]
\W 表示任意一个非字,除了a-zA-Z0-9_以外的任意一个字符 [^a-zA-Z0-9_]
2)自定义的 []
比如 [0-9]
注意: 上面用到两个符号:
- 表示范围 如 [0-9] 表示从0到9 [a-z] 表示字母从a-z
^ 表示非 取反 [^0-9] 表示除了0到9以外的字符
3、元字符
A 只匹配字符串开头
b 匹配单词边界
B 匹配单词边界之外的任意字符
d 匹配数字字符,它与[0-9]相同
D 匹配非数字字符
s 匹配空白字符
S 匹配非空白字符
[] 包围一个字符类,字符类包括:[0-9] [a-z] [a-zA-Z] 等类似。
() 包围一个字符分组或定义一个反引用
{} 大括号用来精确指定匹配元字符出现的次数
$ 匹配行尾
^ 匹配行首
* 匹配前面的子表达式零次或多次。要匹配 * 字符,请使用 *
+ 匹配前面的子表达式一次或多次。要匹配 + 字符,请使用 +
? 匹配前面的子表达式零次或一次,或指明一个非贪婪限定符 ?
. 匹配除换行之外的任何字符
引出下一个元字符
w 匹配任何只包含下划线和字母数字字符的字符串,它与 [a-zA-Z0-9_]相同
W 匹配没有下划线和字母数字字符的字符串
4、模式修正符
i 完成不区分大小写的搜索
g 查找所有出现(all occurrences,完成全局搜索)
m 将一个字符串视为多行(m就表示多(multiple))。默认情况下,^和$字符匹配字符串中的最开始和最末尾。使用m修饰符将使^和$匹配字符串中每行的开始
s 将一个字符串视为一行,忽略其中的所有换行符;它与m修饰符正好相反
x 忽略正则表达式中的空白和注释
U 第一次匹配后停止。默认情况下,将找到最后一个匹配字符结果。利用这个修饰符可以在第一次匹配后停止。进而形式循环匹配
u (PCRE_UTF8) 此修正符启用了一个 PCRE 中与 Perl 不兼容的额外功能。模式字符串被当成 UTF-8。本修正符在 Unix 下自 PHP 4.1.0 起可用,在 win32 下自 PHP 4.2.3 起可用。
以上就是我汇总的了,有问题及时联系,只是我个人理解,并非权威
相关文章推荐
- Java简单字符串插值实现
- C# 正则判断一个数字的格式是否有逗号的代码
- C#常用正则大全分享
- Erlang语法学习笔记:变量、原子、元组、列表、字符串
- 实例详解C#正则表达式
- php正则替换处理HTML页面的方法
- php的正则处理函数总结分析
- PHP正则表达式之定界符和原子介绍
- 正则方式的自动小偷抓网程序
- asp 去掉html中的table正则代码函数
- mysqlhotcopy 正则使用小技巧
- PHP 定界符 使用技巧
- js下函数般调用正则的方法附代码
- PHP EOT定界符的使用详解
- php实现使用正则将文本中的网址转换成链接标签
- php下正则来匹配dede模板标签的代码
- asp 验证输入网址是否有效并可以访问 与正则验证输入网址
- php 正则 过滤html 的超链接
- JS正则中的RegExp对象对象
- perl 正则表达式