zoukankan      html  css  js  c++  java
  • 正则表达式-语法大全

    一、基本概念
            正则表达式,又称规则表达式。(英语:Regular Expression,在代码中常简写为regex、regexp或RE),计算机科学的一个概念。正则表达式通常被用来检索、替换那些符合某个模式(规则)的文本。
    许多程序设计语言都支持利用正则表达式进行字符串操作。例如,在Perl中就内建了一个功能强大的正则表达式引擎。正则表达式这个概念最初是由Unix中的工具软件(例如sed和grep)普及开的。正则表达式通常缩写成“regex”,单数有regexp、regex,复数有regexps、regexes、regexen。
     
    二、简介
            正则表达式是对字符串(包括普通字符(例如,a 到 z 之间的字母)和特殊字符(称为“元字符”))操作的一种逻辑公式,就是用事先定义好的一些特定字符、及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串”用来表达对字符串的一种过滤逻辑。正则表达式是一种文本模式,该模式描述在搜索文本时要匹配的一个或多个字符串。
     
    三、语法介绍
    1、常用的元字
    代码
    说明
    .
    匹配除换行符以外的任意字符
    w
    匹配字母或数字或下划线或汉字
    s
    匹配任意的空白符
    d
    匹配数字
    
    匹配单词的开始或结束
    ^
    匹配字符串的开始
    $
    匹配字符串的结束
    举例:
    匹配-QQ号必须为5位到12位数字时:^d{5,12}$
    匹配-固定电话的:0dd-dddddddd
     
    2、 常用的限定符
    代码/语法
    说明
    *
    重复零次或更多次
    +
    重复一次或更多次
    ?
    重复零次或一次
    {n}
    重复n次
    {n,}
    重复n次或更多次
    {n,m}
    重复n到m次
    举例:
    匹配-Windows后面跟1个或更多数字:Windowsd+
    匹配-一行的第一个单词:^w+
     
    3、常用的反义代码
    代码/语法
    说明
    W
    匹配任意不是字母,数字,下划线,汉字的字符
    S
    匹配任意不是空白符的字符
    D
    匹配任意非数字的字符
    B
    匹配不是单词开头或结束的位置
    [^x]
    匹配除了x以外的任意字符
    [^aeiou]
    匹配除了aeiou这几个字母以外的任意字符
    举例:
    匹配- 不包含空白符的字符串: S+
    匹配- 用尖括号括起来的以a开头的字符串: <a[^>]+>


    4、分组语法
    分类
    代码/语法
    说明
    捕获
    (exp)
    匹配exp,并捕获文本到自动命名的组里
    (?<name>exp)
    匹配exp,并捕获文本到名称为name的组里,也可以写成(?'name'exp)
    (?:exp)
    匹配exp,不捕获匹配的文本,也不给此分组分配组号
    零宽断言
    (?=exp)
    匹配exp前面的位置
    (?<=exp)
    匹配exp后面的位置
    (?!exp)
    匹配后面跟的不是exp的位置
    (?<!exp)
    匹配前面不是exp的位置
    注释
    (?#comment)
    这种类型的分组不对正则表达式的处理产生任何影响,用于提供注释让人阅读
    举例:这点开始难度有点大了
    匹配-w+的组名指定为Word: (?'Word'w+)),
     
    5、懒惰限定符
     
     
    代码/语法
    说明
    *?
    重复任意次,但尽可能少重复
    +?
    重复1次或更多次,但尽可能少重复
    ??
    重复0次或1次,但尽可能少重复
    {n,m}?
    重复n到m次,但尽可能少重复
    {n,}?
    重复n次以上,但尽可能少重复
     
    6、其他
     
     
    代码/语法
    说明
    a
    报警字符(打印它的效果是电脑嘀一声)
    
    通常是单词分界位置,但如果在字符类里使用代表退格
    制表符,Tab
    回车
    v
    竖向制表符
    f
    换页符
    换行符
    e
    Escape
    nn
    ASCII代码中八进制代码为nn的字符
    xnn
    ASCII代码中十六进制代码为nn的字符
    unnnn
    Unicode代码中十六进制代码为nnnn的字符
    cN
    ASCII控制字符。比如cC代表Ctrl+C
    A
    字符串开头(类似^,但不受处理多行选项的影响)
    
    字符串结尾或行尾(不受处理多行选项的影响)
    z
    字符串结尾(类似$,但不受处理多行选项的影响)
    G
    当前搜索的开头
    p{name}
    Unicode中命名为name的字符类,例如p{IsGreek}
    (?>exp)
    贪婪子表达式
    (?<x>-<y>exp)
    平衡组
    (?im-nsx:exp)
    在子表达式exp中改变处理选项
    (?im-nsx)
    为表达式后面的部分改变处理选项
    (?(exp)yes|no)
    把exp当作零宽正向先行断言,如果在这个位置能匹配,使用yes作为此组的表达式;否则使用no
    (?(exp)yes)
    同上,只是使用空表达式作为no
    (?(name)yes|no)
    如果命名为name的组捕获到了内容,使用yes作为表达式;否则使用no
    (?(name)yes)
    同上,只是使用空表达式作为no
     
    四、在线正则校验
    https://tool.oschina.net/regex/
     
     
     
     
  • 相关阅读:
    Python学习-字符编码浅析
    python元组,集合类型,及字典补充
    python字符串,列表常用操作
    python流程控制
    Python之线程&进程
    yii框架的中的一些使用介绍
    《最牛B的Linux Shell命令》笔记
    CentOS6.8上安装epel
    mysql 5.7 Group Replication
    mysql5.7 参数记录 (持续更新)
  • 原文地址:https://www.cnblogs.com/mrwhite2020/p/13167122.html
Copyright © 2011-2022 走看看