正则表达式

由于工作要求,需要会使用正则表达式,因此从网上查找了一些关于正则表达式的知识,记录下来,以备后用。
所谓正则表达式,在我理解,其实就是用一系列抽象出来的符号去匹配一些想要查找的内容,如大家熟知的 \n 匹配一个换行符,这些符号包括普通字母,数字,其它一些特殊符号。既然说到正则表达式是有一系列抽象符号组合而成,那么需要知道正则表达式的构成。正则表达式=普通字符+元字符
下面首先说一下普通字符,普通字符是有一下两种字符组成,
1.没有显示指定元字符的可打印字符
2.没有显示指定为元字符的不可打印字符
非打印字符:
- \cx 匹配由x指定的控制字符,例如\cM 匹配一个回车符
- \f 匹配一个换页符
- \n 匹配一个换行符
- \r 匹配一个回车符
- \s 匹配任何空白字符,包括空格,制表符,换页符等
- \S 匹配任何非空白字符 [^\f\n\r\t\v]效果一样
- \t 匹配一个制表符
- \v 匹配一个垂直制表符
- \d 匹配任何一个十进制数
- \D 匹配任一非十进制字符
- \w 匹配任一‘字’的字符,包括数字,汉字,字母等
- \W 匹配任一非’ 字’ 的字符
- \b 匹配字分界线,即字和字之间的空间
- \B 匹配非字分界线
- \A 匹配目标的开头,例如:一段话的开头,一个单词的开头等
- \Z 匹配目标的结尾或位于结尾的换行符前(独立于多行模式)这个不懂
- \z 匹配目标的结尾
- \G 匹配目标中的第一个匹配位置,例如匹配单词‘Regular’则匹配’R’前面
- \xhh 匹配十六进制代码为hh 的字符
- \ddd 匹配八进制代码为ddd的字符,或backreference

特殊字符:
特殊字符就是具有特殊含义的字符,若要匹配特殊字符,必须首先使字符转移(加 ‘\’),当然若有匹配‘\’则需要转义,即’\’
正则表达式中还有一个’贪婪’模式和’非贪婪’模式
贪婪模式:* + ? 这三个字符都是’贪婪’的,因为它们尽可能多的匹配文本,通过在这三个特殊字符的后面添加一个 ‘?’就能变为非‘贪婪’模式,即只匹配匹配到的所有字符中的第一个
- RegExp 也匹配 \n 或 \r 要匹配$则需要 \$
- () 一个正则表达式的子表达式要匹配() 使用()
- * 匹配前面的自表达式次或多次 匹配过程对大小写不敏感
- + 匹配前面的子表达式一次多次 匹配过程对大小写不敏感
- . 匹配除换行符之外的所有单字符
- ? 匹配前面的子表达式零次或者一次,或指明一个非贪婪限定
- \ 将下一个字符标记为 特殊字符 原意字符 向后引用 八进制转义符
- ^ 匹配输入字符串的开始位置。若在方括号表达式中使用,则表示不接受方括号内的字符集合
- { 标记限定符表达式的开始
- | 表明 或 的关系
限定符:
限定符用来指定正则表达式给定的一个组件必须要出现多少次才符合匹配要求,共有6种限定符,分别如下:
- * 匹配前面的子表达零次或多次(不匹配一次)。例如zo*能匹配‘z’ 以及‘zoo’。 等价于{0,}
- + 匹配前面的子表达一次或多次,等价于{1,}
- ? 匹配前面的子表达式零次或者一次。等价于{0,1}
- {n} n是一个非负整数,匹配确定的n次,不能多也不能少
- {n,} n是一个非负整数,匹配至少n次
- {n,m} n和m均为非负的整数,其中n<=m 最少匹配n次且最多匹配m次
元字符:

  • [xyz] 字符集合 能匹配所包含的任意一个字符 但不是多个只能是一个字符
  • [a-z] 字符范围 匹配指定范围内的任意单个字符,小写
  • [A-Z] 字符范围 匹配指定范围内的任意单个字符,大写 连字符 - 表示范围
  • [^xyz] 负值字符集合,匹配未包含的任意字符
  • [^a-z] 负值字符范围,匹配任何不在指定范围内的任意字符
    正则表达式的运算优先级顺序:
    从高到低:
    \
    () (?:) (?=) (?!) []
      • ? {n} {n,} {n,m}
        ^ $ (任何元字符或者任何字符)
        |
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值