正则表达式 教学.ppt
《正则表达式 教学.ppt》由会员分享,可在线阅读,更多相关《正则表达式 教学.ppt(23页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、正则表达式正则表达式 教学教学基本说来,正则表达式是一种用来描述一定数量文本的模式。Regex代表Regular Express。一段文本就是最基本的模式,简单的匹配相同的文本。什么是正什么是正则表达式表达式正则表达式引擎是一种可以处理正则表达式的软件。通常,引擎是更大的应用程序的一部分。在软件世界,不同的正则表达式并不互相兼容。本教程会集中讨论Perl 5 类型的引擎,因为这种引擎是应用最广泛的引擎。同时我们也会提到一些和其他引擎的区别。许多近代的引擎都很类似,但不完全一样。例如.NET正则库,JDK正则包。不同的正不同的正则表达式引擎表达式引擎最基本的正则表达式由单个文字符号组成。如,它将
2、匹配字符串中第一次出现的字符“a”。如对字符串“Jack is a boy”。“J”后的“a”将被匹配。而第二个“a”将不会被匹配。正则表达式也可以匹配第二个“a”,这必须是你告诉正则表达式引擎从第一次匹配的地方开始搜索。在文本编辑器中,你可以使用“查找下一个”。在编程语言中,会有一个函数可以使你从前一次匹配的位置开始继续向后搜索。类似的,会匹配“About cats and dogs”中的“cat”。这等于是告诉正则表达式引擎,找到一个,紧跟一个,再跟一个。要注意,正则表达式引擎缺省是大小写敏感的。除非你告诉引擎忽略大小写,否则不会匹配“Cat”。文字符号文字符号特殊字符对于文字字符,有11
3、个字符被保留作特殊用途。他们是:$.|?*+()这些特殊字符也被称作元字符。如果你想在正则表达式中将这些字符用作文本字符,你需要用反斜杠“”对其进行换码(escape)。例如你想匹配“1+1=2”,正确的表达式为.需要注意的是,也是有效的正则表达式。但它不会匹配“1+1=2”,而会匹配“123+111=234”中的“111=2”。因为“+”在这里表示特殊含义(重复1次到多次)。在编程语言中,要注意,一些特殊的字符会先被编译器处理,然后再传递给正则引擎。因此正则表达式在C+中要写成“1+1=2”。为了匹配“C:temp”,你要用正则表达式。而在C+中,正则表达式则变成了“C:temp”。不可显示
4、字符可以使用特殊字符序列来代表某些不可显示字符:代表Tab(0 x09)代表回车符(0 x0D)代表换行符(0 x0A)要注意的是Windows中文本文件使用“rn”来结束一行而Unix使用“n”。知道正则表达式引擎是如何工作的有助于你很快理解为何某个正则表达式不像你期望的那样工作。有两种类型的引擎:文本导向(text-directed)的引擎和正则导向(regex-directed)的引擎。Jeffrey Friedl把他们称作DFA和NFA引擎。本文谈到的是正则导向的引擎。这是因为一些非常有用的特性,如“惰性”量词(lazy quantifiers)和反向引用(backreferences
5、),只能在正则导向的引擎中实现。所以毫不意外这种引擎是目前最流行的引擎。你可以轻易分辨出所使用的引擎是文本导向还是正则导向。如果反向引用或“惰性”量词被实现,则可以肯定你使用的引擎是正则导向的。你可以作如下测试:将正则表达式应用到字符串“regex not”。如果匹配的结果是regex,则引擎是正则导向的。如果结果是regex not,则是文本导向的。因为正则导向的引擎是“猴急”的,它会很急切的进行表功,报告它找到的第一个匹配。正正则表达式引擎的内部工作机制表达式引擎的内部工作机制这是需要你理解的很重要的一点:即使以后有可能发现一个“更好”的匹配,正则导向的引擎也总是返回最左边的匹配。当把应用
6、到“He captured a catfish for his cat”,引擎先比较和“H”,结果失败了。于是引擎再比较和“e”,也失败了。直到第四个字符,匹配了“c”。匹配了第五个字符。到第六个字符没能匹配“p”,也失败了。引擎再继续从第五个字符重新检查匹配性。直到第十五个字符开始,匹配上了“catfish”中的“cat”,正则表达式引擎急切的返回第一个匹配的结果,而不会再继续查找是否有其他更好的匹配。正正则导则导向的引擎向的引擎总总是返回最左是返回最左边边的的匹配匹配字符集是由一对方括号“”括起来的字符集合。使用字符集,你可以告诉正则表达式引擎仅仅匹配多个字符中的一个。如果你想匹配一个“a
7、”或一个“e”,使用。你可以使用匹配gray或grey。这在你不确定你要搜索的字符是采用美国英语还是英国英语时特别有用。相反,将不会匹配graay或graey。字符集中的字符顺序并没有什么关系,结果都是相同的。你可以使用连字符“-”定义一个字符范围作为字符集。匹配0到9之间的单个数字。你可以使用不止一个范围。匹配单个的十六进制数字,并且大小写不敏感。你也可以结合范围定义与单个字符定义。匹配一个十六进制数字或字母X。再次强调一下,字符和范围定义的先后顺序对结果没有影响。字符集字符集查找一个可能有拼写错误的单词,比如 或。查找程序语言的标识符,。(*表示重复0或多次)查找C风格的十六进制数。(+表
8、示重复一次或多次)字符集的一些字符集的一些应应用用在左方括号“”后面紧跟一个尖括号“”,将会对字符集取反。结果是字符集将匹配任何不在方括号中的字符。不像“.”,取反字符集是可以匹配回车换行符的。需要记住的很重要的一点是,取反字符集必须要匹配一个字符。并不意味着:匹配一个q,后面没有u跟着。它意味着:匹配一个q,后面跟着一个不是u的字符。所以它不会匹配“Iraq”中的q,而会匹配“Iraq is a country”中的q和一个空格符。事实上,空格符是匹配中的一部分,因为它是一个“不是u的字符”。如果你只想匹配一个q,条件是q后面有一个不是u的字符,我们可以用后面将讲到的向前查看来解决。取反字符
9、集取反字符集需要注意的是,在字符集中只有4个 字符具有特殊含义。它们是:“-”。“”代表字符集定义的结束;“”代表转义;“”代表取反;“-”代表范围定义。其他常见的元字符在字符集定义内部都是正常字符,不需要转义。例如,要搜索星号*或加号+,你可以用。当然,如果你对那些通常的元字符进行转义,你的正则表达式一样会工作得很好,但是这会降低可读性。在字符集定义中为了将反斜杠“”作为一个文字字符而非特殊含义的字符,你需要用另一个反斜杠对它进行转义。将会匹配一个反斜杠和一个X。“-”都可以用反斜杠进行转义,或者将他们放在一个不可能使用到他们特殊含义的位置。我们推荐后者,因为这样可以增加可读性。比如对于字符
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 正则表达式 教学 正则 表达式
限制150内