正则表达式-语法大全
一、基本概念
正则表达式,又称规则表达式。(英语:Regular Expression,在代码中常简写为regex、regexp或RE),计算机科学的一个概念。正则表达式通常被用来检索、替换那些符合某个模式(规则)的文本。
许多程序设计语言都支持利用正则表达式进行字符串操作。例如,在Perl中就内建了一个功能强大的正则表达式引擎。正则表达式这个概念最初是由Unix中的工具软件(例如sed和grep)普及开的。正则表达式通常缩写成“regex”,单数有regexp、regex,复数有regexps、regexes、regexen。
二、简介
正则表达式是对字符串(包括普通字符(例如,a 到 z 之间的字母)和特殊字符(称为“元字符”))操作的一种逻辑公式,就是用事先定义好的一些特定字符、及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串”用来表达对字符串的一种过滤逻辑。正则表达式是一种文本模式,该模式描述在搜索文本时要匹配的一个或多个字符串。
三、语法介绍
1、常用的元字
代码
|
说明
|
.
|
匹配除换行符以外的任意字符
|
\w
|
匹配字母或数字或下划线或汉字
|
\s
|
匹配任意的空白符
|
\d
|
匹配数字
|
\b
|
匹配单词的开始或结束
|
^
|
匹配字符串的开始
|
$
|
匹配字符串的结束
|
举例:
匹配-QQ号必须为5位到12位数字时:^\d{5,12}$
匹配-固定电话的:0\d\d-\d\d\d\d\d\d\d\d
2、 常用的限定符
代码/语法
|
说明
|
*
|
重复零次或更多次
|
+
|
重复一次或更多次
|
?
|
重复零次或一次
|
{n}
|
重复n次
|
{n,}
|
重复n次或更多次
|
{n,m}
|
重复n到m次
|
举例:
匹配-Windows后面跟1个或更多数字:Windows\d+
匹配-一行的第一个单词:^\w+
3、常用的反义代码
代码/语法
|
说明
|
\W
|
匹配任意不是字母,数字,下划线,汉字的字符
|
\S
|
匹配任意不是空白符的字符
|
\D
|
匹配任意非数字的字符
|
\B
|
匹配不是单词开头或结束的位置
|
[^x]
|
匹配除了x以外的任意字符
|
[^aeiou]
|
匹配除了aeiou这几个字母以外的任意字符
|
举例:
匹配- 不包含空白符的字符串: \S+
匹配- 用尖括号括起来的以a开头的字符串: <a[^>]+>
4、分组语法
分类
|
代码/语法
|
说明
|
捕获
|
(exp)
|
匹配exp,并捕获文本到自动命名的组里
|
(?<name>exp)
|
匹配exp,并捕获文本到名称为name的组里,也可以写成(?'name'exp)
|
|
(?:exp)
|
匹配exp,不捕获匹配的文本,也不给此分组分配组号
|
|
零宽断言
|
(?=exp)
|
匹配exp前面的位置
|
(?<=exp)
|
匹配exp后面的位置
|
|
(?!exp)
|
匹配后面跟的不是exp的位置
|
|
(?<!exp)
|
匹配前面不是exp的位置
|
|
注释
|
(?#comment)
|
这种类型的分组不对正则表达式的处理产生任何影响,用于提供注释让人阅读
|
举例:这点开始难度有点大了
匹配-\w+的组名指定为Word: (?'Word'\w+)),
5、懒惰限定符
代码/语法
|
说明
|
*?
|
重复任意次,但尽可能少重复
|
+?
|
重复1次或更多次,但尽可能少重复
|
??
|
重复0次或1次,但尽可能少重复
|
{n,m}?
|
重复n到m次,但尽可能少重复
|
{n,}?
|
重复n次以上,但尽可能少重复
|
6、其他
代码/语法
|
说明
|
\a
|
报警字符(打印它的效果是电脑嘀一声)
|
\b
|
通常是单词分界位置,但如果在字符类里使用代表退格
|
\t
|
制表符,Tab
|
\r
|
回车
|
\v
|
竖向制表符
|
\f
|
换页符
|
\n
|
换行符
|
\e
|
Escape
|
\0nn
|
ASCII代码中八进制代码为nn的字符
|
\xnn
|
ASCII代码中十六进制代码为nn的字符
|
\unnnn
|
Unicode代码中十六进制代码为nnnn的字符
|
\cN
|
ASCII控制字符。比如\cC代表Ctrl+C
|
\A
|
字符串开头(类似^,但不受处理多行选项的影响)
|
\Z
|
字符串结尾或行尾(不受处理多行选项的影响)
|
\z
|
字符串结尾(类似$,但不受处理多行选项的影响)
|
\G
|
当前搜索的开头
|
\p{name}
|
Unicode中命名为name的字符类,例如\p{IsGreek}
|
(?>exp)
|
贪婪子表达式
|
(?<x>-<y>exp)
|
平衡组
|
(?im-nsx:exp)
|
在子表达式exp中改变处理选项
|
(?im-nsx)
|
为表达式后面的部分改变处理选项
|
(?(exp)yes|no)
|
把exp当作零宽正向先行断言,如果在这个位置能匹配,使用yes作为此组的表达式;否则使用no
|
(?(exp)yes)
|
同上,只是使用空表达式作为no
|
(?(name)yes|no)
|
如果命名为name的组捕获到了内容,使用yes作为表达式;否则使用no
|
(?(name)yes)
|
同上,只是使用空表达式作为no
|
四、在线正则校验
https://tool.oschina.net/regex/

【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了