Welcome

首页 / 软件开发 / C++ / 深入浅出之正则表达式

深入浅出之正则表达式2010-01-05 csdn 白途思前言:

半年前我对正则表达式产生了兴趣,在网上查找过不少资料,看过不少的教程,最后在使用一个正则表达式工具RegexBuddy时发现他的教程写的非常好,可以说是我目前见过最好的正则表达式教 程。于是一直想把他翻译过来。这个愿望直到这个五一长假才得以实现,结果就有了这篇文章。关于本 文的名字,使用“深入浅出”似乎已经太俗。但是通读原文以后,觉得只有用“深入浅 出”才能准确的表达出该教程给我的感受,所以也就不能免俗了。

本文是Jan Goyvaerts为RegexBuddy写的教程的译文,版权归原作者所有,欢迎转载。但是为了尊重原作者和译者的劳动,请注明出处!谢谢!

1.什么是正则表达式

基本说来,正则表 达式是一种用来描述一定数量文本的模式。Regex代表Regular Express。本文将用 <<regex>>来表示一段具体的正则表达式。

一段文本就是最基本的模式,简单 的匹配相同的文本。

2.不同的正则表达式引擎

正则表达式引擎是一 种可以处理正则表达式的软件。通常,引擎是更大的应用程序的一部分。在软件世界,不同的正则表达 式并不互相兼容。本教程会集中讨论Perl 5 类型的引擎,因为这种引擎是应用最广泛的引擎。同时我们 也会提到一些和其他引擎的区别。许多近代的引擎都很类似,但不完全一样。例如.NET正则库,JDK正则 包。

3.文字符号

最基本的正则表达式由单个文字符号组成。如 <<a>>,它将匹配字符串中第一次出现的字符“a”。如对字符串“Jack is a boy”。“J”后的“a”将被匹配。而第二个“a”将不会 被匹配。

正则表达式也可以匹配第二个“a”,这必须是你告诉正则表达式引擎从第一次匹配 的地方开始搜索。在文本编辑器中,你可以使用“查找下一个”。在编程语言中,会有一个 函数可以使你从前一次匹配的位置开始继续向后搜索。

类似的,<<cat>>会匹 配“About cats and dogs”中的“cat”。这等于是告诉正则表达式引擎,找到 一个<<c>>,紧跟一个<<a>>,再跟一个<<t>>。

要 注意,正则表达式引擎缺省是大小写敏感的。除非你告诉引擎忽略大小写,否则<<cat>>不 会匹配“Cat”。

·特殊字符

对于文字字符 ,有11个字符被保留作特殊用途。他们是:

[ ] ^ $ .| ? * + ( )

这些特殊 字符也被称作元字符。

如果你想在正则表达式中将这些字符用作文本字符,你需要用反斜杠 “”对其进行换码 (escape)。例如你想匹配“1+1=2”,正确的表达式为 <<1+1=2>>.

需要注意的是,<<1+1=2>>也是有效的正则表达式。 但它不会匹配“1+1=2”,而会匹配“123+111=234”中的“111=2”。 因为“+”在这里表示特殊含义(重复1次到多次)。

在编程语言中,要注意,一 些特殊的字符会先被编译器处理,然后再传递给正则引擎。因此正则表达式<<1+2=2>>在 C++中要写成“1\+1=2”。为了匹配“C: emp”,你要用正则表达式 <<C:\temp>>。而在C++中,正则表达式则变成了“C:\\temp”。

·不可显示字符

可以使用特殊字符序列来代表某些不可显示字符:

<< >>代表Tab (0x09)

<< >>代表回车符(0x0D)

<< >>代表换行符 (0x0A)

要注意的是Windows中文本文件使用“ ”来结束一行而Unix使用 “ ”。