码迷,mamicode.com
首页 > 其他好文 > 详细

正则小记忆

时间:2021-04-16 12:24:45      阅读:0      评论:0      收藏:0      [点我收藏+]

标签:code   换行   字符   使用   分组   一个   空白   结束   pre   

元字符

.  匹配除换行符以外的任意字符

\w 匹配字母或数字或下划线或汉字

\s 匹配任意的空白符

\d  匹配数字

\b  匹配单词的开始或结束

^  匹配字符串的开始

$  匹配字符串的结束

重复

*  重复零次或更多次

+  重复一次或更多次

? 重复零次或一次

{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

正则小记忆

标签:code   换行   字符   使用   分组   一个   空白   结束   pre   

原文地址:https://www.cnblogs.com/Paul-Yellow/p/14665733.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!