简单来说,正则表达式就是用一些特定的符号来代替字符串
代码 | 说明 |
---|---|
. | 匹配除\n以外的任意字符 |
\w | 匹配数字或字母或 _ |
\W | 匹配非数字或字母或 _ |
\s | 匹配任意的空白符(空格,换行,字表符) |
\S | 匹配非空白符 |
\d | 匹配所有数字 |
\D | 匹配非数字 |
\b | 匹配单词的开始或结束(边界) |
\B | 匹配非单词边界 |
^ | 匹配字符串的开始 |
$ | 匹配字符串的结束 |
代码 | 说明 |
---|---|
\f | 匹配一个换页符 |
\n | 匹配一个换行符 |
\r | 匹配一个回车符 |
\t | 匹配一个水平制表符 |
\v | 匹配一个垂直制表符 |
* | 匹配* |
. | 匹配. |
\ | 匹配\ |
代码 | 说明 |
---|---|
x | y | 匹配x或y |
[xyz] | 字符集合。匹配所包含的任意一个字符。例如’[abc]’ 可以匹配 “plain” 中的 ‘a’。 |
[^xyz] | 负值字符集合。匹配未包含的任意字符。例如’[^abc]’ 可以匹配 “plain” 中的’p’、‘l’、‘i’、‘n’。 |
[a-z] | 字符范围。匹配指定范围内的任意字符 |
[^a-z] | 负值字符范围。匹配任何不在指定范围内的任意字符。 |
回到顶部 目录
分类 | 代码 | 说明 |
---|---|---|
捕获 | (exp) | 匹配exp,并捕获文本到自动命名的组里面 |
(?<name>exp) | 匹配exp,并捕获文本到名称为name的组里 | |
(?:exp) | 匹配exp,不捕获匹配的文本,也不给此分组分配编号 | |
零度断言 | (?=exp) | 匹配exp前面的位置 |
(?<=exp) | 匹配exp后面的位置 | |
(?!exp) | 匹配后面跟着不是exp的位置 | |
(?<!exp) | 匹配强面不是exp的位置 | |
注释 | (?#comment) | 这种类型的分组不对正则表达式的处理产生任何影响,只是提供注释让人阅读 |
每使用一对()小括号,就是分了一个小组,并且每个小组都有一个编号
系统自动分配编号的原则是:
后向引用是指通过反斜杠\
加上 数字(编号)的方式来重复使用某一组的正则表达式
例如:(\d+)\s{1}\1
这个式子中可看出\d+
是第1组,编号就是1,后面的\1
就是引用了前面这一组的内容,相当于 (\d+)\s{1}(\d+)
匹配宽度为0,在匹配元素的位置设置断点
比如一个字符串ddexpaa
dd(?=exp):匹配exp前面的dd
(?=exp)aa:匹配exp后面的aa
比如一个字符串aabab
贪婪的正则匹配:a.*b ==> 匹配到aabab一个结果
懒惰的正则匹配:a.*?b ==> 匹配到aab和ab两个结果
代码 | 说明 |
---|---|
* | 重复0次或者无数次 |
+ | 重复1次或者无数次 |
? | 重复0次或者1次 |
{n} | 重复n次 |
{n,} | 重复n次或者重复n次以上 |
{n, m} | 重复n到m次 |
代码 | 说明 |
---|---|
*? | 重复任意次,但尽可能少重复 |
+? | 重复1次或者更多次,但尽可能少重复 |
?? | 重复0次或者1次,但尽可能少重复 |
{n,m}? | 重复n到m次,但尽可能少重复 |
{n,}? | 重复n次以上,但尽可能少重复 |
回到顶部 目录
/^1[3456789][0-9]{9}$/
/^(0\d{2,3}-\d{7,8})(-\d{1,4})?$/
/(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/
/^[a-zA-Z]\w{5,17}$/
/[1-9]\d{5}(?!\d)/
/^[1-9][0-9]{4,9}$/
/^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$/
/^\d*(?:\.\d{0,2})?$/
/(http|ftp|https):\/\/[\w\-_]+(\.[\w\-_]+)+([\w\-\.,@?^=%&:/~\+#]*[\w\-\@?^=%&/~\+#])?/
/((?:(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d)\\.){3}(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d))/
/^(\d{4})\-(\d{2})\-(\d{2}) (\d{2})(?:\:\d{2}|:(\d{2}):(\d{2}))$/.test(str) || /^(\d{4})\-(\d{2})\-(\d{2})$/
/^[0-9]$/ 或者 /^\d$/
/^[a-zA-Z]+$/
/^[\\u4E00-\\u9FA5]+$/
/^[a-z]+$/
/^[A-Z]+$/
/<("[^"]*"|'[^']*'|[^'">])*>/
回到顶部 目录
本文地址:https://blog.csdn.net/qq_45007419/article/details/107235024
如对本文有疑问, 点击进行留言回复!!
网友评论