正则表达式(一)从初学到精通正则表达式

正则表达式(一)从初学到精通正则表达式

ID:14144056

大小:56.50 KB

页数:6页

时间:2018-07-26

正则表达式(一)从初学到精通正则表达式_第1页
正则表达式(一)从初学到精通正则表达式_第2页
正则表达式(一)从初学到精通正则表达式_第3页
正则表达式(一)从初学到精通正则表达式_第4页
正则表达式(一)从初学到精通正则表达式_第5页
资源描述:

《正则表达式(一)从初学到精通正则表达式》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

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

2、处!谢谢! 1.     什么是正则表达式基本说来,正则表达式是一种用来描述一定数量文本的模式。Regex代表RegularExpress。本文将用<>来表示一段具体的正则表达式。一段文本就是最基本的模式,简单的匹配相同的文本。 2.     不同的正则表达式引擎正则表达式引擎是一种可以处理正则表达式的软件。通常,引擎是更大的应用程序的一部分。在软件世界,不同的正则表达式并不互相兼容。本教程会集中讨论Perl5类型的引擎,因为这种引擎是应用最广泛的引擎。同时我们也会提到一些和其他引擎的区别。许多近代的引擎都很类似,但不完全一样。例如.NET正则库,JDK正则包。 3.     

3、文字符号最基本的正则表达式由单个文字符号组成。如<>,它将匹配字符串中第一次出现的字符“a”。如对字符串“Jackisaboy”。“J”后的“a”将被匹配。而第二个“a”将不会被匹配。正则表达式也可以匹配第二个“a”,这必须是你告诉正则表达式引擎从第一次匹配的地方开始搜索。在文本编辑器中,你可以使用“查找下一个”。在编程语言中,会有一个函数可以使你从前一次匹配的位置开始继续向后搜索。类似的,<>会匹配“Aboutcatsanddogs”中的“cat”。这等于是告诉正则表达式引擎,找到一个<>,紧跟一个<>,再跟一个<>。要注意,正则表达式引擎缺省是大小写敏感

4、的。除非你告诉引擎忽略大小写,否则<>不会匹配“Cat”。 ·       特殊字符对于文字字符,有11个字符被保留作特殊用途。他们是:[]^$.

5、?*+()这些特殊字符也被称作元字符。如果你想在正则表达式中将这些字符用作文本字符,你需要用反斜杠“”对其进行换码(escape)。例如你想匹配“1+1=2”,正确的表达式为<<1+1=2>>.需要注意的是,<<1+1=2>>也是有效的正则表达式。但它不会匹配“1+1=2”,而会匹配“123+111=234”中的“111=2”。因为“+”在这里表示特殊含义(重复1次到多次)。在编程语言中,要注意,一些特殊的字符会先被编译器处理,然

6、后再传递给正则引擎。因此正则表达式<<1+2=2>>在C++中要写成“1\+1=2”。为了匹配“C:temp”,你要用正则表达式<>。而在C++中,正则表达式则变成了“C:\\temp”。 ·       不可显示字符可以使用特殊字符序列来代表某些不可显示字符:<>代表Tab(0x09)<>代表回车符(0x0D)<<>>代表换行符(0x0A)要注意的是Windows中文本文件使用“r”来结束一行而Unix使用“”。 4.     正则表达式引擎的内部工作机制知道正则表达式引擎是如何工作的有助于你很快理解为何某个正则表达式不像你期望的

7、那样工作。有两种类型的引擎:文本导向(text-directed)的引擎和正则导向(regex-directed)的引擎。JeffreyFriedl把他们称作DFA和NFA引擎。本文谈到的是正则导向的引擎。这是因为一些非常有用的特性,如“惰性”量词(lazyquantifiers)和反向引用(backreferences),只能在正则导向的引擎中实现。所以毫不意外这种引擎是目前最流行的引擎。你可以轻易分辨出所使用的引擎是文本导向还是正则导向。如果反向引用或“惰性”量词被实现,则可以肯定你使用的引擎是正则导向的。你可以作如下测试:将正则表达式<

8、regexnot>>应用到字符串“r

9、egexnot”。如果匹配的结果是regex,则引擎是正则导向的。如果结果是regexnot,则是文本导向的。因为正则导向的引擎是“猴急”的,它会很急切的进行表功,报告它找到的第一个匹配。 ·       正则导向的引擎总是返回最左边的匹配这是需要你理解的很重要的一点:即使以后有可能发现一个“更好”的匹配,正则导向的引擎也总是返回最左边的匹配。当把<>应用到“Hecapturedacatfishfo

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。