正则表达式学习笔记

正则表达式学习(js)

概览

先拿数字举例

符号 含义
\d 数字
\d? 0个或1个数字
\d+ 1个或多个数字
\d* 0个或多个数字
\d{3} 3个数字
\d{3,5} 3个到5个数字

几个常用的例子

  1. 单词边界\b

    比如我们就像匹配单词is,像qishi这样的不要匹配,我们就需要\bis\b

  2. 点.表示任意字符

    如果我们就需要匹配点.,那我们就需要转义\.

  3. 匹配//

    网址中经常有//,要匹配这个,也需要转义\/\/

  4. 分组()

    分组之后,我们可以提取其中的内容

  5. 或者[]

    在匹配日期中,[-/],就可以要么匹配-,要么匹配/

  6. 开头、结尾

    ^表示以什么开始,$表示以什么结束

正则对象

创建一个正则对象

var reg = new RegExp('\\bis\\b','g')

\\,第一个是为了转义,第二个是配合后面的\b

修饰符

  • g: global 表示全文搜索
  • i: ignore case 忽略大小写。默认大小写敏感
  • m:multiple lines 多行搜索

多行匹配就是让后面的行同样适用于第一行的规则。
没加换行修饰符

正则表达式学习笔记_第1张图片
image.png

第二行,第三行的都没有匹配到。

如果我们加上换行修饰符


正则表达式学习笔记_第2张图片

元字符

正则表达式由两种基本字符组成,一类是原义文本字符,写什么就匹配什么,我们看到的就是要匹配的。第二类就是元字符,元字符就是在正则表达式中有特殊含义的非字母字符。


正则表达式学习笔记_第3张图片
1553516159529.png

字符类

正则表达式学习笔记_第4张图片
1553516410201.png

我们使用[]构造了一类字符,这一类字符中,可以是abc中的任意一个。

字符类取反

正则表达式学习笔记_第5张图片
1553516535536.png

范围类

如果我们要需要一个类,包括数字从5到9,我们需要这样[5 6 7 8 9],如果数字多的话,会很麻烦
所以就需要范围类了

正则表达式学习笔记_第6张图片
image.png

连写

[a-zA-Z],就把大小写都包括了。
如果我们不光包括大小写,还需要包括-
[a-zA-Z-],后面加一个-就可以了。

js预定义类和边界

上一节中,看到我们可以自定义类,这样已经方便了我们书写,但是还不够,为此,正则表达式还给我们提供了预定义类来匹配常见的字符类。


正则表达式学习笔记_第7张图片
image.png

我们可以自己构造:
ab[0-9][^\r\n]
也可以使用正则的预定义类
ab\d.

边界

正则表达式学习笔记_第8张图片

举例

正则表达式学习笔记_第9张图片
image.png

量词

我们希望匹配一个连续出现20次的数字的字符串

好麻烦

正则表达式学习笔记_第10张图片

贪婪模式和非贪婪模式

正则表达式学习笔记_第11张图片

这个会匹配多少?
默认是贪婪模式,会都匹配。
如果我们想让它尽可能少的匹配,我们就设置为非贪婪模式。


正则表达式学习笔记_第12张图片

举例:


正则表达式学习笔记_第13张图片

分组

我们有这样的场景,匹配字符串Byron出现三次的场景。
学习了量词之后,我们可以这样:Byron{3}
但是这并不是我们需要的,因为它代表的是n出现三次。

正则表达式学习笔记_第14张图片

正则表达式学习笔记_第15张图片

上面的例子,如果我们只是想把或作用onCa,我们可以这样

正则表达式学习笔记_第16张图片

反向引用

场景:


不光是 -变成了 /,日期的顺序也变了。

我们要替换的内容还在字符串本身里面,就相当于变量的概念了。

image.png

note:如果没有分组的话,$就表示原义了。

忽略分组

正则表达式学习笔记_第17张图片
image.png

前瞻和后顾

正则表达式学习笔记_第18张图片
正则表达式学习笔记_第19张图片

举例


正则表达式学习笔记_第20张图片

这里的(?=\d)不是正则部分,它是类型断言部分。

你可能感兴趣的:(正则表达式学习笔记)