Perl 中的正则表达式.doc_第1页
Perl 中的正则表达式.doc_第2页
Perl 中的正则表达式.doc_第3页
Perl 中的正则表达式.doc_第4页
Perl 中的正则表达式.doc_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

Perl 中的正则表达式 9Perl 中的正则表达式 正则表达式的三种形式 正则表达式中的常用模式 正则表达式的 8 大原则 正则表达式是 Perl 语言的一大特色,也是 Perl 程序中的一点难点,不过如果大家能够很好的掌握他,就可以轻易地用正则表达式来完成字符串处理的任务,当然在 CGI 程序设计中就更能得心应手了。下面我们列出一些正则表达式书写时的一些基本语法规则。9.1 正则表达式的三种形式首先我们应该知道 Perl 程序中,正则表达式有三种存在形式,他们分别是:匹配:m/ (还可以简写为 / ,略去 m)替换:s/转化:tr/这三种形式一般都和 = 或 ! 搭配使用(其中 = 表示相匹配,在整条语句中读作 does,! 表示不匹配,在整条语句中读作 doesnt),并在左侧有待处理的标量变量。如果没有该变量和 = ! 操作符,则默认为处理 $_ 变量中的内容。举例如下:$str = I love Perl;$str = m/Perl/; # 表示如果在 $str 中发现 Perl 字符串,则返回 1 否则返回 0。$str = s/Perl/BASH/; # 表示将变量 $str 中的 Perl 字符串替换为 BASH,如果发生此替换则返回 1,否则返回 0。$str ! tr/A-Z/a-z/; # 表示将变量 $str 中的所有大写字母转化为小写字母,如果转化发生了则返回 0,否则返回 1。另外还有:foreach (array) s/a/b/; # 此处每次循环将从 array 数组中取出一个元素存放在 $_ 变量中,并对 $_ 进行替换处理。while () print if (m/error/); # 这一句稍微复杂一些,他将打印 FILE 文件中所有包含 error 字符串的行。Perl 的正则表达式中如果出现 () ,则发生匹配或替换后 () 内的模式被 Perl 解释器自动依次赋给系统 $1, $2 . 请看下面的例子:$string = I love perl;$string = s/(love)/; # 此时 $1 = love,并且该替换的结果是将 $string 变为 I perl$string = i love perl;$string = s/(i)(.*)(perl)/$2/; # 这里 $1 = i,$2 = love ,$3 = perl,并且替换后 $string 变为 love 替换操作 s/ 还可以在末尾加上 e 或 g 参数,他们的含义分别为:s/g 表示把待处理字符串中所有符合 的模式全部替换为 字符串,而不是只替换第一个出现的模式。s/e 表示将把 部分当作一个运算符,这个参数用的不多。比如下面的例子:$string = i:love:perl;$string = s/:/*/; #此时 $string=i*love:perl;$string = i:love:perl;$string = s/:/*/g; #此时 $string=i*love*perl; $string = tr/*/ /; #此时 $string=i love perl; $string = www22cgi44;$string = s/(d+)/$1*2/e; # (/d+)代表 $string 中的一个或多个数字字符,将这些数字字符执行 *2 的操作,因此最后 $string 变成了 www44cgi88。下面给出一个完整的例子:#!/usr/bin/perlprint请输入一个字符串!n;$string = ; # 代表标准输入,会让使用者输入一字符串chop($string); # 将$string最后一个换行的字符n删除掉if($string = /perl/)print(输入的字符串中有 perl 这个字符串!n;如果输入的字符串含有 perl 这个字符串的话,就会显示后面的提示信息。9.2 正则表达式中的常用模式下面是正则表达式中的一些常用模式。/pattern/ 结果 .匹配除换行符以外的所有字符x?匹配 0 次或一次 x 字符串x*匹配 0 次或多次 x 字符串,但匹配可能的最少次数x+匹配 1 次或多次 x 字符串,但匹配可能的最少次数.*匹配 0 次或一次的任何字符.+匹配 1 次或多次的任何字符m匹配刚好是 m 个 的指定字符串m,n匹配在 m个 以上 n个 以下 的指定字符串m,匹配 m个 以上 的指定字符串匹配符合 内的字符匹配不符合 内的字符0-9匹配所有数字字符a-z匹配所有小写字母字符0-9匹配所有非数字字符a-z匹配所有非小写字母字符匹配字符开头的字符$匹配字符结尾的字符d匹配一个数字的字符,和 0-9 语法一样d+匹配多个数字字符串,和 0-9+ 语法一样D非数字,其他同 dD+非数字,其他同 d+w英文字母或数字的字符串,和 a-zA-Z0-9 语法一样w+和 a-zA-Z0-9+ 语法一样W非英文字母或数字的字符串,和 a-zA-Z0-9 语法一样W+和 a-zA-Z0-9+ 语法一样s空格,和 ntrf 语法一样s+和 ntrf+ 一样S非空格,和 ntrf 语法一样S+和 ntrf+ 语法一样b匹配以英文字母,数字为边界的字符串B匹配不以英文字母,数值为边界的字符串a|b|c匹配符合a字符 或是b字符 或是c字符 的字符串abc匹配含有 abc 的字符串(pattern)() 这个符号会记住所找寻到的字符串,是一个很实用的语法。第一个 () 内所找到的字符串变成 $1 这个变量或是 1 变量,第二个 () 内所找到的字符串变成 $2 这个变量或是 2 变量,以此类推下去。 /pattern/ii 这个参数表示忽略英文大小写,也就是在匹配字符串的时候,不考虑英文的大小写问题。如果要在 pattern 模式中找寻一个特殊字符,如 *,则要在这个字符前加上 符号,这样才会让特殊字符失效下面给出一些例子: 范例说明/perl/找到含有 perl 的字符串/perl/找到开头是 perl 的字符串/perl$/找到结尾是 perl 的字符串/c|g|i/找到含有 c 或 g 或 i 的字符串/cg2,4i/找到 c 后面跟着 2个到 4个 g ,再跟着 i 的字符串/cg2,i/找到 c 后面跟着 2个以上 g ,再跟着 i 的字符串/cg2i/找到 c 后面跟着 2个 g,再跟着 i 的字符串/cg*i/找到 c 后面跟着 0个或多个 g ,再跟着 i 的字符串,如同/cg0,1i/cg+i/找到 c 后面跟着一个以上 g,再跟着 i 的字符串,如同/cg1,i/cg?i/找到 c 后面跟着 0个或是 1个 g ,再跟着 i 的字符串,如同/cg0,1i/c.i/找到 c 后面跟着一个任意字符,再跟着 i 的字符串/c.i/找到 c 后面跟着二个任意字符,再跟着 i 的字符串/cgi/找到符合有这三个字符任意一个的字符串/cgi/找到没有这三个字符中任意一个的字符串/d/找寻符合数字的字符,可以使用/d+/来表示一个或是多个数字组成的字符串/D/找寻符合不是数字的字符,可以使用/D+/来表示一个或是更多个非数字组成的字符串/*/找寻符合 * 这个字符,因为 * 在常规表达式中有它的特殊意思,所以要在这个特殊符号前加上 符号,这样才会让这个特殊字符失效/abc/i找寻符合 abc 的字符串而且不考虑这些字符串的大小写9.3 正则表达式的八大原则如果在 Unix 中曾经使用过 sed、awk、grep 这些命令的话,相信对于 Perl 语言中的正则表达式(Regular Expression)不会感到陌生。Perl 语言由于有这个功能,所以对字符串的处理能力非常强。在Perl语言的程序中,经常可以看到正则表达式的运用,在 CGI 程序设计中也不例外。正则表达式是初学 Perl 的难点所在,不过只要一旦掌握其语法,你就可以拥有几乎无限的模式匹配能力,而且 Perl 编程的大部分工作都是掌握常规表达式。下面给大家介绍几条正则表达式使用过程中的 8 大原则。 正则表达式在对付数据的战斗中可形成庞大的联盟这常常是一场战争。我们要记住下面八条原则: 原则1:正则表达式有三种不同形式(匹配(m/ /),替换(s/ / /eg)和转换(tr/ / /)。 原则2:正则表达式仅对标量进行匹配( $scalar = m/a/; 可以工作; array = m/a/ 将把array作为标量对待,因此可能不会成功)。 原则3:正则表达式匹配一个给定模式的最早的可能匹配。缺省时,仅匹配或替换正则表达式一次( $a = string string2; $a = s/string/ /; 导致 $a = string 2)。 原则4:正则表达式能够处理双引号所能处理的任意和全部字符( $a = m/$varb/ 在匹配前把varb扩展为变量;如果 $varb = a $a = as,$a = s/$varb/ /; 等价于 $a = s/a/ /; ,执行结果使 $a = s )。 原则5:正则表达式在求值过程中产生两种情况:结果状态和反向引用: $a= m/pattern/ 表示 $a 中是否有子串 pattern 出现,$a = s/(word1)(word2)/$2$1/ 则“调换”这两个单词。 原则6:正则表达式的核心能力在于通配符和多重匹配运算符以及它们如何操作。$a = m/w+/ 匹配一个或多个单词字符;$a = m/d/ 匹配零个或多个数字。 原则7:如果欲匹配不止一个字符集合

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论