zoukankan      html  css  js  c++  java
  • RegExp 正则

           正则,就是一条规则,用于检验字符串的格式,目标就是字符串。

    正则的定义

      1.var reg=new RegExp();

      2.var reg=/格式/;

    正则的方法

      两大功能,一个是匹配,匹配成功就是true,第二个是捕获,如果有就拿出来。

      test()用于匹配

      exec()用于捕获

    正则的修饰符

      1.区不区分大小写    i  代表忽略大小写

      2.全局   g  代表全局匹配

      3.m 代表多行匹配

      用法1.var reg=new RegExp("hello",g)

             2.var reg=/hello/gi

    字符串方法中跟正则有关的

      1.match()查找一个或多个与正则相匹配的  有就返回的是查找的结果,没有就是null

      2.search()匹配和正则相同的字符,有就返回索引,没有就是-1

      3.replace()匹配和正则相同的,并替换掉,返回的是替换后的字符串

    正则的方括号

      [abc] 代表查找方括号中的任何字符

      [^abc] 代表查找任何一个不在方括号之间的字符

      [0-9] 查找0-9之间的数字

      [a-z] 查找任何小写a到小写z的字符

      [A-Z] 查找任何大写A到大写Z的字符

      [A-z] 查找大写A到小写z的字符

      (red|blue|green)

    元字符

      .代表单个字符

      w代表单词字符   数字   字母  _

      W代表非单词字符

      d代表数字

      D代表非数字

      s代表空白字符

      S代表非空白字符

      代表单词边界

      B代表非单词边界

    量词

    1.n+ 代表至少1个n的字符

    2.n* 代表0个或多个n

    3.n?包含0个或1个n

    4.n{x} 包含x个n

    5.n{x,}包含至少x个n

    6.n{x,y}包含大于等于x个小于等于y个n

    7.n$  包含以n结尾的字符串

    8.^n 包含以n开头的字符串

    9.?=n 指定字符串后面紧跟的n的字符串

    正则的理解

      1.正则的懒惰性

      每一次在exec()中捕获的时候,只捕获第一次匹配的内容,而不往下捕获了。我们把这叫正则的懒惰性,每一次捕获的开始位置都是从0开始

             解决方法:

             使用修饰符g

      2.正则的贪婪性

      每一次匹配都是按照最长的出结果,我们把这种功能叫正则的贪婪性。

           解决方法

           在元字符量词后面加?

    正则的分组捕获

         : 正则带()  在数分组的个数是从左往右

      列:var reg=/(a)(b)/  就相当于大正则里面带了俩个小正则

       分组的捕获前提是正则存在分组,不仅把大正则的内容捕获到,把小正则的内容也捕获到。

            分组捕获的作用

        1.改变优先级

        2.分组引用

        var reg=/(w)1(w)2/

        var st="ssdd"

        var s=reg.test(st)

        console.log(s)

        2代表和第二个分组出现一模一样的内容,1代表和第一个分组出现一模一样的内容

      Reg中的规则是第一个是一个分组 且是一个单词字符 第二个是个分组引用要求和第一组一模一样,第三个是第二个分组且是一个单词字符,第四个是一个分组引用,要求和第二组一模一样。

      怎样解除分组中分组捕获呢?

        如果你不想捕获某一个分组中的内容,在这个分组的前面加上?:就可以了

     

  • 相关阅读:
    CF1051D Bicolorings dp
    loj2480 [CEOI2017]One-Way Streets 边双+树上差分
    有趣的支配树
    AtCoder Regular Contest 81
    [BZOJ5305][HAOI2018]苹果树(DP)
    [BZOJ4699]树上的最短路(最短路+线段树)
    [BZOJ3507][CQOI2014]通配符匹配(DP+Hash)
    [Luogu4724][模板]三维凸包(增量构造法)
    [BZOJ5317][JSOI2018]部落战争(闵可夫斯基和)
    [WC2014]时空穿梭(莫比乌斯反演)
  • 原文地址:https://www.cnblogs.com/yangzhiqiang/p/10139714.html
Copyright © 2011-2022 走看看