平时需要用到比较少,但是一到关键时刻却又需要,老是忘记
。写个备忘
元字符
常用元字符表:
字符 说明
.
匹配除换行符以外的任意字符
\w
匹配字母、数字、汉字、下划线
\s
匹配任意空白符
\d
匹配数字
\b
匹配单词的开头或结尾
^
匹配字符串的开头
$
匹配字符串的结尾
字符转义
如果要查找元字符本身,必须使用\来消除元字符的特殊意义。eg:c:\\windows 匹配 c:\windows
反义
字符 说明
\W
匹配字母、数字、汉字、下划线以外的任意字符
\S
匹配任意不是空白的字符
\D
匹配任意不是数字的字符
\B
匹配不是单词开头或结尾的位置
[^x]
匹配除x以外的任意字符
[^aieou]
匹配除aieou以外的任意字符
重复
字符 说明
*
重复0或多次
+
重复1或多次
? 重复0或1次
{n}
重复n次
{n,}
重复n到多次
{n,m}
重复n到m次
eg:[a-z]*: 匹配任意长度的小写字母串 aa,ab,ac
分支条件
有几种规则,当满足其中任意一种规则时都可成功匹配,规则用 | 隔开
eg:0\d{2}-\d{8}|0\d{3}-\d{7}:匹配两种号码:1)三位区号+八位号码 2)四位区号+七位号码
分组
用小括号()来指定分组,默认分组号从1开始
eg:(24[0-5]|25[0-4]|[01]?\d\d?\.){3}(24[0-5]|25[0-4]|[01]?\d\d?) :匹配ip地址
常用分组语法:
符号 说明
(exp)
匹配exp,并捕获文本到自动命名的分组
(?<name>exp)
匹配exp,捕获文本到命名为name的分组
(:exp)
匹配exp,不捕获文本,也不分配组号
零宽断言
符号
说明
(?=exp)
匹配exp前面的位置
(?<=exp)
匹配exp后面的位置
(?!=exp)
匹配后面跟的不是exp的位置
(?<!exp)
匹配前面跟的不是exp的位置
eg:
1)\b\w+(?=ing\b) i am singging while she is dancing 匹配 sing 和 danc
2)(\b?<=re)\w+\b reading a book 匹配 ading
贪婪和懒惰
字符 说明
*?
重复任意次,但尽可能少重复
+?
重复1或多次,但尽可能少重复
??
重复0或1次,但尽可能少重复
{n,m}?
重复n到m次,但尽可能少重复
{n,}?
重复n到多次,但尽可能少重复
分享到:
相关推荐
在Qt框架中,正则表达式(Regular Expression)是一种强大的文本处理工具,它允许程序员以结构化的方式匹配、查找、替换或验证字符串。本项目针对Qt的lineEdit组件,通过正则表达式实现了输入限制功能,使得lineEdit...
正则表达式(Regular Expression,简称regex)是一种强大的文本处理工具,它用于匹配、查找、替换等操作,涉及字符串处理的各个领域。正则表达式转换工具是专门针对这一需求而设计的,它能帮助用户将输入的内容转换...
在IT领域,正则表达式(Regular Expression,简称regex)是一种强大的文本处理工具,它能够进行复杂的模式匹配、查找、替换等操作。在本话题中,我们将探讨如何使用PowerBuilder 11.5这一经典的开发环境来实现正则...
C语言正则表达式库是用于在C编程环境中处理和匹配正则表达式的软件库。这个库名为PCRE(Perl Compatible Regular Expressions),正如其名,它与Perl语言中的正则表达式语法高度兼容,提供了丰富的功能和强大的匹配...
例如,"子程序_正则文本替换"可能就是一个易语言中用于执行正则表达式替换的子程序,它接收输入的文本、正则表达式模式和替换字符串,然后返回经过替换操作的新文本。 1. **正则表达式基础** - **元字符**:如`.`...
标题中的“pb 使用正则表达式源码pbregexp”指的是在PowerBuilder(简称pb)环境中,利用名为“pbregexp”的正则表达式组件来实现源代码级别的正则表达式操作。PowerBuilder是一款流行的可视化的、面向对象的软件...