正则表达式入门笔记

前端之家收集整理的这篇文章主要介绍了正则表达式入门笔记前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

正则表达式是描述某些复杂字符串规则的工具,它是记录文本规则的代码

元字符
代码 说明
. 匹配除了换行符以外的任意字符
\w 匹配字符或数字或下划线或汉字
\s 匹配任意空白字符,包括空格、制表符,换行符、中文全角空格
\d 匹配数字
\b 匹配单词的开始或结束
^ 匹配字符串的开始
$ 匹配字符串的结束
为了避免重复输入,可以使用{数字}表示重复的次数,如:\d{8}表示\d必须连续重复匹配8次

转义字符

如果想查找元字符本身的话,比如查找.或者*就出现了问题,因为它们会被解释成别的意思,可以使用\来取消这些字符的特殊意义。如:\.和\*,或者\\。

重复

常用的限定符
代码/语法 说明
* 重复零次或更多次
+ 重复一次或更多次
重复零次或一次
{n} 重复n次
{n,} 重复n次或更多次
{n,m} 重复n到m次

字符类

想查找数字、字母和空白是很简单的,因为已经有了对应这些字符集合的与字符,但是如果你想匹配没有预定义元字符的字符集合,但是如果想匹配没有预定义的元字符集合,改怎么办?只需在方括号里将它们列出就行,如:[aeIoU]就匹配任何一个英文元音字母,[.?!]匹配标点符号(.或?或!)。

也可以指定一个字符范围,如:[a-z0-9A-Z_]

分枝条件

正则表达式里的分枝条件指的是有几种规则,如果满足其中任意一种规则都应该当成匹配,具体方法是用|把不同的规则分隔开。

分组

用小括号来指定字表达式(也叫做分组),然后就可以指定这个字表达式的重复次数了。

反义

有时候需要查找不属于某个能简单定义字符类的字符,需要用到反义。

常用的反义代码
代码/语法 说明
\W 匹配任意不是字母、数字、下划线、汉字的字符
\S 匹配任意不是空白符的字符
\D 匹配任意非数字的字符
\B 匹配不是单词开头或结束的位置
[^x] 匹配除了x以外的任意字符
[^aeIoU] 匹配除了aeIoU这几个字母以外的任意字符

后向引用

使用小括号指定一个字表达式后,匹配这个字表达式的文本(也就是此分组捕获的内容)可以在表达式或其他程序中做进一步处理。默认情况下,每个分组或自动拥有一个组号,规则是:从左向右,以分组的左括号为标识,第一个出现的分组组号为1,第二个为2,以此类推

后向引用用于重复搜索前面某个分组匹配文本如:\1代表分组1匹配的文本。如:\b(\w+)\b\s+\1\b可以用来匹配重复的单词

也可以自己指定字表达式的组名,语法为:(?<Word>\w+)或者吧尖括号换成'也行,这样就把\w+指定为Word了,要反响引用这个分组捕获的内容,你可以使用=k<Word>

常用分组语法
分类 代码/语法 说明
捕获 (exp) 匹配exp,并捕获文本到自动命名的组里
捕获 (?<name>exp 匹配exp,并捕获文本到名词为name的组里,也可以写成(?'name'exp)
捕获 (?:exp) 匹配exp,不捕获匹配文本,也不给词分组分配组号
零宽断言 (?=exp) 匹配exp前面的位置
零宽断言 (?<=exp) 匹配exp后面的位置
零宽断言 (?!=exp) 匹配后面跟的不是exp的位置
零宽断言 (<!exp) 匹配前面不是exp的位置
注释 (?#comment) 这种类型的分组不对正则表达式的处理产生任何影响,用于提供注释让人阅读。

零宽断言:用于查找某些内容(但并不包括这些内容)之前或之后的东西,也就是说他们\b,^,$那样用于指定一个位置,这个位置应该满足一定的条件(即断言)

负向零宽断言:用于想要确保某个字符没有出现,但并不想去匹配它。它只匹配一个位置,并不消费任何字符。

零宽度负预测先行断言(?!exp):断言此位置后面不能匹配表达式exp

零宽度负回顾后发断言(?<!exp):断言此位置的前面不能匹配表达式exp

贪婪与懒惰
代码/语法 说明
*? 重复任意次,但尽可能少重复
+? 重复1次或更多次,但尽可能少重复
?? 重复0次或1次,但尽可能少重复
{n,m}? 重复n到m次,但尽可能少重复
{n,}? 重复n次以上,但尽可能少重复

猜你在找的正则表达式相关文章