zoukankan      html  css  js  c++  java
  • 正则表达式规则

    字符集:

    字符组 : [字符组]
    在同一个位置可能出现的各种字符组成了一个字符组,在正则表达式中用[]表示
    字符分为很多类,比如数字、字母、标点等等。
    假如你现在要求一个位置"只能出现一个数字",那么这个位置上的字符只能是0、1、2...9这10个数之一。
    正则
    待匹配字符
    匹配
    结果
    说明
    [0123456789]
    8
    True
    在一个字符组里枚举合法的所有字符,字符组里的任意一个字符
    和"待匹配字符"相同都视为可以匹配
    [0123456789]
    a
    False
    由于字符组中没有"a"字符,所以不能匹配
     
    [0-9]
     
    7
    True
    也可以用-表示范围,[0-9]就和[0123456789]是一个意思
     
    [a-z]
     
    s
     
    True
     
    同样的如果要匹配所有的小写字母,直接用[a-z]就可以表示
     
    [A-Z]
     
    B
     
    True
     
    [A-Z]就表示所有的大写字母
     
    [0-9a-fA-F]
     
    e
     
    True
     
    可以匹配数字,大小写形式的a~f,用来验证十六进制字符
    
    

     字符:

    元字符
     
    匹配内容
    匹配除换行符以外的任意字符
    w 匹配字母或数字或下划线
    s 匹配任意的空白符
    d 匹配数字
    匹配一个换行符
    匹配一个制表符
     匹配一个单词的结尾
    ^ 匹配字符串的开始
    $ 匹配字符串的结尾
    W
    匹配非字母或数字或下划线
    D
    匹配非数字
    S
    匹配非空白符
    a|b
    匹配字符a或字符b
    ()
    匹配括号内的表达式,也表示一个组
    [...]
    匹配字符组中的字符
    [^...]
    匹配除了字符组中字符的所有字符

     量词

    量词
    用法说明
    * 重复零次或更多次
    + 重复一次或更多次
    ? 重复零次或一次
    {n} 重复n次
    {n,} 重复n次或更多次
    {n,m} 重复n到m次

    参考地址:http://www.cnblogs.com/Eva-J/articles/7228075.html#_label10

    举例:(正则表达式的测试地址http://tool.chinaz.com/regex/)

    匹配6个完全相同的数字

     (d)1{5}

    解释:1表示引用第一个括号-字符组()。

    
    
  • 相关阅读:
    Codeforces 912 D. Fishes (贪心、bfs)
    Codeforces 908 D.New Year and Arbitrary Arrangement (概率&期望DP)
    HDU
    HDU
    POJ-2299 Ultra-QuickSort (树状数组)
    deque!
    HDU
    乘法逆元
    Codeforces 911D. Inversion Counting (数学、思维)
    Codeforces 909E. Coprocessor (拓扑、模拟)
  • 原文地址:https://www.cnblogs.com/lixiaoxuan/p/9028802.html
Copyright © 2011-2022 走看看