表达式的构造
正则表达式中/i,/g,/ig,/gi,/m的区别和含义
/i (忽略大小写)
/g (全文查找出现的所有匹配字符)
/m (多行查找)
/gi(全文查找、忽略大小写)
/ig(全文查找、忽略大小写)
\t
|
制表符 ('\u0009')
|
\n
|
新行(换行)符 ('\u000A')
|
\r
|
回车符 ('\u000D')
|
\f
|
换页符 ('\u000C')
|
\a
|
报警 (bell) 符 ('\u0007')
|
\e
|
转义符 ('\u001B')
|
字符类
|
|
[abc]
|
a、b 或 c(简单类)
|
[^abc]
|
任何字符,除了 a、b 或 c(否定)
|
[a-zA-Z]
|
a 到 z 或 A 到 Z,两头的字母包括在内(范围)
|
[a-d[m-p]]
|
a 到 d 或 m 到 p:[a-dm-p](并集)
|
[a-z&&[def]]
|
d、e 或 f(交集)
|
[a-z&&[^bc]]
|
a 到 z,除了 b 和 c:[ad-z](减去)
|
[a-z&&[^m-p]]
|
a 到 z,而非 m 到 p:[a-lq-z](减去)
|
预定义字符类
|
|
.
|
任何字符(与行结束符 可能匹配也可能不匹配)
|
\d
|
数字:[0-9]
|
\D
|
非数字: [^0-9]
|
\s
|
空白字符:[ \t\n\x0B\f\r]
|
\S
|
非空白字符:[^\s]
|
\w
|
单词字符:[a-zA-Z_0-9]
|
\W
|
非单词字符:[^\w]
|
POSIX 字符类(仅 US-ASCII)
|
|
\p{Lower}
|
小写字母字符:[a-z]
|
\p{Upper}
|
大写字母字符:[A-Z]
|
\p{ASCII}
|
所有 ASCII:[\x00-\x7F]
|
\p{Alpha}
|
字母字符:[\p{Lower}\p{Upper}]
|
\p{Digit}
|
十进制数字:[0-9]
|
\p{Alnum}
|
字母数字字符:[\p{Alpha}\p{Digit}]
|
\p{Punct}
|
标点符号:!"#$%&'()*+,-./:;<=>?@[\]^_`{|}~
|
\p{Graph}
|
可见字符:[\p{Alnum}\p{Punct}]
|
\p{Print}
|
可打印字符:[\p{Graph}\x20]
|
\p{Blank}
|
空格或制表符:[ \t]
|
\p{Cntrl}
|
控制字符:[\x00-\x1F\x7F]
|
\p{XDigit}
|
十六进制数字:[0-9a-fA-F]
|
\p{Space}
|
空白字符:[ \t\n\x0B\f\r]
|
java.lang.Character 类(简单的 java 字符类型 )
|
|
\p{javaLowerCase}
|
等效于 java.lang.Character.isLowerCase()
|
\p{javaUpperCase}
|
等效于 java.lang.Character.isUpperCase()
|
\p{javaWhitespace}
|
等效于 java.lang.Character.isWhitespace()
|
\p{javaMirrored}
|
等效于 java.lang.Character.isMirrored()
|
Unicode 块和类别的类
|
|
\p{InGreek}
|
Greek 块(简单 块 )中的字符
|
\p{Lu}
|
大写字母(简单类别 )
|
\p{Sc}
|
货币符号
|
\P{InGreek}
|
所有字符,Greek 块中的除外(否定)
|
[\p{L}&&[^\p{Lu}]]
|
所有字母,大写字母除外(减去)
|
边界匹配器
|
|
^
|
行的开头
|
$
|
行的结尾
|
\b
|
单词边界
|
\B
|
非单词边界
|
\A
|
输入的开头
|
\G
|
上一个匹配的结尾
|
\Z
|
输入的结尾,仅用于最后的结束符 (如果有的话)
|
\z
|
输入的结尾
|
Greedy 数量词
|
|
X ?
|
X ,一次或一次也没有
|
X *
|
X ,零次或多次
|
X +
|
X ,一次或多次
|
X {n }
|
X ,恰好 n 次
|
X {n ,}
|
X ,至少 n 次
|
X {n ,m }
|
X ,至少 n 次,但是不超过 m 次
|
Reluctant 数量词
|
|
X ??
|
X ,一次或一次也没有
|
X *?
|
X ,零次或多次
|
X +?
|
X ,一次或多次
|
X {n }?
|
X ,恰好 n 次
|
X {n ,}?
|
X ,至少 n 次
|
X {n ,m }?
|
X ,至少 n 次,但是不超过 m 次
|
Possessive 数量词
|
|
X ?+
|
X ,一次或一次也没有
|
X *+
|
X ,零次或多次
|
X ++
|
X ,一次或多次
|
X {n }+
|
X ,恰好 n 次
|
X {n ,}+
|
X ,至少 n 次
|
X {n ,m }+
|
X ,至少 n 次,但是不超过 m 次
|
Logical 运算符
|
|
XY
|
X 后跟 Y
|
X |Y
|
X 或 Y
|
(X )
|
X,作为捕获组
|
Back 引用
|
|
\n
|
任何匹配的 n th 捕获组
|
引用
|
|
\
|
Nothing,但是引用以下字符
|
\Q
|
Nothing,但是引用所有字符,直到 \E
|
\E
|
Nothing,但是结束从 \Q 开始的引用
|
特殊构造(非捕获)
|
|
(?:X )
|
X ,作为非捕获组
|
(?idmsux-idmsux)
|
Nothing,但是将匹配标志由 on 转为 off
|
(?idmsux-idmsux: X )
|
X ,作为带有给定标志 on - off 的非捕获组
|
(?=X )
|
X ,通过零宽度的正 lookahead
|
(?!X )
|
X ,通过零宽度的负 lookahead
|
(?<=X )
|
X ,通过零宽度的正 lookbehind
|
(?<!X )
|
X ,通过零宽度的负 lookbehind
|
(?>X )
|
X ,作为独立的非捕获组
|
组和捕获
捕获组可以通过从左到右计算其开括号来编号。例如,在表达式 ((A)(B(C))) 中,存在四个这样的组:
1
|
((A)(B(C)))
|
2
|
\A
|
3
|
(B(C))
|
4
|
(C)
|
分享到:
相关推荐
在Qt框架中,正则表达式(Regular Expression)是一种强大的文本处理工具,它允许程序员以结构化的方式匹配、查找、替换或验证字符串。本项目针对Qt的lineEdit组件,通过正则表达式实现了输入限制功能,使得lineEdit...
正则表达式(Regular Expression,简称regex)是一种强大的文本处理工具,它用于匹配、查找、替换等操作,涉及字符串处理的各个领域。正则表达式转换工具是专门针对这一需求而设计的,它能帮助用户将输入的内容转换...
在IT领域,正则表达式(Regular Expression,简称regex)是一种强大的文本处理工具,它能够进行复杂的模式匹配、查找、替换等操作。在本话题中,我们将探讨如何使用PowerBuilder 11.5这一经典的开发环境来实现正则...
例如,"子程序_正则文本替换"可能就是一个易语言中用于执行正则表达式替换的子程序,它接收输入的文本、正则表达式模式和替换字符串,然后返回经过替换操作的新文本。 1. **正则表达式基础** - **元字符**:如`.`...
标题中的“pb 使用正则表达式源码pbregexp”指的是在PowerBuilder(简称pb)环境中,利用名为“pbregexp”的正则表达式组件来实现源代码级别的正则表达式操作。PowerBuilder是一款流行的可视化的、面向对象的软件...
在易语言中,正则表达式是进行文本处理、数据提取和搜索的关键工具,尤其在处理中文字符时显得尤为重要。本文将深入探讨易语言中的正则表达式匹配中文的原理、方法以及应用。 正则表达式(Regular Expression)是一...
C语言正则表达式库是用于在C编程环境中处理和匹配正则表达式的软件库。这个库名为PCRE(Perl Compatible Regular Expressions),正如其名,它与Perl语言中的正则表达式语法高度兼容,提供了丰富的功能和强大的匹配...
Java使用正则表达式提取XML节点内容的方法示例 Java使用正则表达式提取XML节点内容的方法示例主要介绍了Java使用正则表达式提取XML节点内容的方法,结合具体实例形式分析了java针对xml格式字符串的正则匹配相关操作...
### 正则表达式在数据库查询中的应用 #### 引言 在数据库管理与应用程序开发中,查询数据是一项常见的任务。传统的SQL查询虽然强大,但在处理复杂查询时可能存在一定的局限性,尤其是涉及到文本数据的模式匹配时。...
正则表达式(Regular Expression,简称regex)是用于在文本中匹配特定模式的强大工具,广泛应用于数据验证、搜索替换和文本处理等领域。正则表达式调试工具是开发人员用来测试和优化这些模式的重要辅助工具。本文将...
正则表达式类库则为VC++和MFC的开发者提供了对正则表达式功能的支持。 "VC、VC++,MFC 正则表达式类库"指的是在MFC中实现或集成的正则表达式处理模块。这个库通常包含一系列的类和函数,允许程序员编写符合特定模式...
在易语言中,正则表达式类是一个非常重要的工具,用于处理字符串的模式匹配和查找。在处理中文文本时,这个功能尤为关键,因为中文字符的编码和处理方式与英文有所不同。 正则表达式是用于匹配字符串模式的一种强大...
《Delphi 2010正则表达式插件详解》 在编程世界中,正则表达式(Regular Expression)是一种强大的文本处理工具,能够帮助开发者高效地进行字符串的匹配、查找、替换等操作。在Delphi 2010这个经典的集成开发环境中...
正则表达式是一种强大的文本处理工具,用于在字符串中进行模式匹配和搜索。在C#编程语言中,正则表达式被广泛应用于数据验证、文本提取、格式转换等多个场景。本项目提供了一个C#编写的正则表达式测试工具,包含完整...
在IT行业中,正则表达式(Regular Expression)是一种强大的文本处理工具,用于匹配、查找、替换等操作。C++作为一种通用编程语言,虽然标准库中没有内置正则表达式支持,但通过第三方库如Boost,我们可以很方便地在...
正则表达式(Regular Expression,简称regex)是一种强大的文本处理工具,它用于匹配、查找、替换等操作,涉及字符串的模式匹配。在本主题中,我们将深入探讨如何使用正则表达式来生成满足特定条件的随机数据。这在...
C# 正则表达式大全 正则表达式是指用来描述字符串模式的表达式,通过使用正则表达式,我们可以轻松地实现字符串的匹配、验证、提取和替换等操作。在 C# 中,我们可以使用 System.Text.RegularExpressions 命名空间...
在IT行业中,正则表达式(Regular Expression)是一种强大的文本处理工具,用于匹配、查找、替换等操作。在本案例中,“易语言正则表达式取网址和名称”指的是使用易语言这一编程环境,结合正则表达式技术来从文本中...
正则表达式作为一种文本处理工具,在计算机编程和数据处理领域中扮演着极其重要的角色。它不仅适用于几乎所有编程语言和计算机平台,而且能够执行复杂的文本搜索、匹配、替换和提取操作。正则表达式的核心是通过定义...
在IT领域,正则表达式(Regular Expression)是一种强大的文本处理工具,用于匹配字符串模式。它们广泛应用于数据验证、搜索、替换等操作。本话题主要关注如何根据正则表达式生成满足该模式的数据,这在测试、数据...