转自:http://tool.chinaz.com/regex/
正则表达式由正常字符,元字符,限定符之类组成。主要是通过元字符增加匹配的灵活性,
一个元字符可以匹配多种一个字符
代码 | 说明 |
---|---|
. | 匹配除换行符以外的任意字符 |
\w | 匹配字母或数字或下划线 |
\s | 匹配任意的空白符 |
\d | 匹配数字 |
\W | 匹配任意不是字母,数字,下划线,汉字的字符 |
\S | 匹配任意不是空白符的字符 |
\D | 匹配任意非数字的字符 |
\B | 匹配不是单词开头或结束的位置 |
[^x] | 匹配除了x以外的任意字符 |
[^aeiou] | 匹配除了aeiou这几个字母以外的任意字符 |
在元字符后面加上一个限定符,可以匹配多个字符
代码 | 说明 |
---|---|
* | 重复零次或更多次 |
+ | 重复一次或更多次 |
? | 重复零次或一次 |
{n} | 重复n次 |
{n,} | 重复n次或更多次 |
{n,m} | 重复n到m次 |
以下加在一个子串前面,表示匹配的位置
代码 | 说明 |
---|---|
\b | 匹配单词的开始或结束 |
^ | 匹配字符串的开始 |
$ | 匹配字符串的结束 |
转自:https://juejin.cn/post/6844903855243657230
如果想做检测,就是我们想要的不是匹配出的字符本身,而是它后面的:
代码 | 含义 |
---|---|
(?=a) | 表示我们需要匹配某样东西的前面。 |
(?!a) | 表示我们需要不匹配某样东西。 |
(?:a) | 表示我们需要匹配某样东西本身。 |
(?<=a) | 表示我们需要匹配某样东西的后面。 |
(?<!a) | 表示我们需要不匹配某样东西,与(?!a)方向相反 |