首页 > 编程 > Python > 正文

Python正则表达式知识汇总

2020-02-16 10:17:34
字体:
来源:转载
供稿:网友

1. 正则表达式语法

  1.1 字符与字符类
     1 特殊字符:/.^$?+*{}[]()|
      以上特殊字符要想使用字面值,必须使用/进行转义
     2 字符类
         1. 包含在[]中的一个或者多个字符被称为字符类,字符类在匹配时如果没有指定量词则只会匹配其中的一个。
       2. 字符类内可以指定范围,比如[a-zA-Z0-9]表示a到z,A到Z,0到9之间的任何一个字符
       3. 左方括号后跟随一个^,表示否定一个字符类,比如[^0-9]表示可以匹配一个任意非数字的字符。
       4. 字符类内部,除了/之外,其他特殊字符不再具备特殊意义,都表示字面值。^放在第一个位置表示否定,放在其他位置表示^本身,-放在中间表示范围,放在字符类中的第一个字符,则表示-本身。

      5. 字符类内部可以使用速记法,比如/d /s /w
    3 速记法
       . 可以匹配除换行符之外的任何字符,如果有re.DOTALL标志,则匹配任意字符包括换行
       /d 匹配一个Unicode数字,如果带re.ASCII,则匹配0-9
      /D 匹配Unicode非数字
       /s 匹配Unicode空白,如果带有re.ASCII,则匹配/t/n/r/f/v中的一个
       /S 匹配Unicode非空白
       /w 匹配Unicode单词字符,如果带有re.ascii,则匹配[a-zA-Z0-9_]中的一个
       /W 匹配Unicode非单子字符

  1.2 量词
     1. ? 匹配前面的字符0次或1次
     2. * 匹配前面的字符0次或多次
     3. + 匹配前面的字符1次或者多次
     4. {m} 匹配前面表达式m次
     5. {m,} 匹配前面表达式至少m次
     6. {,n} 匹配前面的正则表达式最多n次
     7. {m,n} 匹配前面的正则表达式至少m次,最多n次
     注意点:
       以上量词都是贪婪模式,会尽可能多的匹配,如果要改为非贪婪模式,通过在量词后面跟随一个?来实现

  1.3 组与捕获
     1 ()的作用:
       1. 捕获()中正则表达式的内容以备进一步利用处理,可以通过在左括号后面跟随?:来关闭这个括号的捕获功能
      2. 将正则表达式的一部分内容进行组合,以便使用量词或者|
    2 反响引用前面()内捕获的内容:
       1. 通过组号反向引用
         每一个没有使用?:的小括号都会分配一个组好,从1开始,从左到右递增,可以通过/i引用前面()内表达式捕获的内容

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表