zoukankan      html  css  js  c++  java
  • 正则小记忆

    元字符

    .  匹配除换行符以外的任意字符
    
    w 匹配字母或数字或下划线或汉字
    
    s 匹配任意的空白符
    
    d  匹配数字
    
      匹配单词的开始或结束
    
    ^  匹配字符串的开始
    
    $  匹配字符串的结束
    
    

    重复

    *  重复零次或更多次
    
    +  重复一次或更多次
    
    ? 重复零次或一次
    
    {n} 重复n次
    
    {n,}  重复n次或更多次
    
    {n,m} 重复n到m次
    
    

    [] 匹配里面的任意一个

    但是如果你想匹配没有预定义元字符的字符集合(比如元音字母a,e,i,o,u),应该怎么办?

    很简单,你只需要在方括号里列出它们就行了,像[aeiou]就匹配任何一个英文元音字母

    分支条件

    分支条件是用 | 进行区分两部分正则表达式,感觉和的感觉很类似,满足两个部分之一就算是匹配成功

    注意:使用分枝条件时,要注意各个条件的顺序。原因是匹配分枝条件时,将会从左到右地测试每个条件,如果满足了某个分枝的话,就不会去再管其它的条件了。

    分组

    分组用()来指定子表达式,可以重复多个符合分组表达式的字符串。

    贪婪与懒惰

    我感觉首先需要分清什么贪婪和什么是懒惰。对于同一个正则表达式 贪婪 就意味着最长匹配符合规则的字符串中的一段,懒惰就是和贪婪相反,最短的匹配字符串。

    *?      重复任意次,但尽可能少重复
    
    +?      重复1次或更多次,但尽可能少重复
    
    ??      重复0次或1次,但尽可能少重复
    
    {n,m}?  重复n到m次,但尽可能少重复
    
    {n,}?   重复n次以上,但尽可能少重复
    
      
    

    eg:

    
    let str = 'aabab'
    let reg = /a.*b/    //aabab
    let reg1 = /a.*?b/  //aab
    
    
  • 相关阅读:
    Color Length UVA
    从一个n位数中选出m位按顺序组成新数并使其最大 || Erasing and Winning UVA
    Bits Equalizer UVA
    Party Games UVA
    笔记 树状数组--区间查询+区间修改
    算法竞赛入门经典 笔记(1)
    Database UVA
    set有关的函数的用法(The SetStack Computer UVA
    ndk学习之C语言基础复习----结构体、共用体与C++开端
    ndk学习之C语言基础复习----基本数据类型、数组
  • 原文地址:https://www.cnblogs.com/Paul-Yellow/p/14665733.html
Copyright © 2011-2022 走看看