您的位置:首页 > 编程语言 > PHP开发

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 起可用。

以上就是我汇总的了,有问题及时联系,只是我个人理解,并非权威
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息