Perl 中的正则表达式

原帖地址:http://263.aka.org.cn/Lectures/002/Lecture-2.1.2/perl-reg.html

正则表达式的三种形式

首先我们应该知道 Perl 程序中,正则表达式有三种存在形式,他们分别是:

匹配:m/<regexp>/ (或 /<regexp>/ ,略去 m)

替换:s/<pattern>/<replacement>/

转化:tr/<pattern>/<replacemnt>/

这三种形式一般都和 =~ 或 !~ 搭配使用(其中 =~表示相匹配,在整条语句中读作does,!~表示不匹配,在整条语句中读作doesn‘t),并在左侧有待处理的标量变量。如果没有该变量和 =~ !~ 操作符,则默认为处理$_变量中的内容。举例如下:

$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 (<FILE>)
{
   print if (m/error/);
}
#他将打印 FILE 文件中所有包含error 字符串的行。

Perl的正则表达式中如果出现(),则发生匹配或替换后()内的模式被Perl解释器自动依次赋给系统$1, $2, $3...

请看下面的例子:

$string = "I love perl";

$string =~ s/(love)/<$1>/; # 此时 $1 = "love",并且该替换的结果是将 $string 变为 "I <love>; perl"

$string = "i love perl";

$string =~ s/(i)(.*)(perl)/<$3>$2<$1>/;

# 这里$1 = "i",$2 = " love ",$3 = "perl",并且替换后$string 变为 "<perl> love <i>"

替换操作 s/<pattern>/<replacement>/ 还可以在末尾加上 e 或 g 参数,他们的含义分别为:

s/<pattern>/<rep>/g

#表示把待处理字符串中所有符合<pattern>的模式全部替换为<rep>字符串,而不是只替换第一个出现的模式。

s/<pattern>/<replacement>/e

#表示将把<replacement>部分当作一个运算符,这个参数用的不多。

比如下面的例子:

$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 变成了"www44cgi44"。

下面给出一个完整的例子:

#!/usr/bin/perl -w 

print "请输入一个字符串!\n";

my $string = <STDIN>; # <STIDN>;代表标准输入,会让使用者输入一字符串
chomp($string);    # 将$string最后一个换行的字符\n删除掉

if($string =~ /perl/)
{
	print "输入的字符串中有 perl 这个字符串!\n";
}

如果输入的字符串含有perl这个字符串的话,就会显示后面的提示信息。

正则表达式中的常用模式

下面是正则表达式中的一些常用模式。

/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     非数字,其他同 \d

\D+    非数字,其他同 \d+

\w     英文字母或数字的字符串,和 [a-zA-Z0-9] 语法一样

\w+    和[a-zA-Z0-9]+ 语法一样

\W     非英文字母或数字的字符串,和 [^a-zA-Z0-9] 语法一样

\W+    和[^a-zA-Z0-9]+语法一样

\s     空格,和 [\n\t\r\f] 语法一样

\s+    和[\n\t\r\f]+ 一样

\S     非空格,和 [^\n\t\r\f] 语法一样

\S+    和[^\n\t\r\f]+ 语法一样

\b     匹配以英文字母,数字为边界的字符串

\B     匹配不以英文字母,数值为边界的字符串

a|b|c  匹配符合a字符或是b字符 或是c字符 的字符串

abc    匹配含有 abc 的字符串

(pattern)   ()这个符号会记住所找寻到的字符串,是一个很实用的语法。第一个 () 内所找到的字符串变成 $1 这个变量或是 \1 变量,第二个 () 内所找到的字符串变成 $2 这个变量或是 \2 变量,以此类推下去。

/pattern/i  i这个参数表示忽略英文大小写,也就是在匹配字符串的时候,不考虑英文的大小写问题。

\ 如果要在 pattern 模式中找寻一个特殊字符,如 "*",则要在这个字符前加上 \ 符号,这样才会让特殊字符失效

下面给出一些例子:

范例       说明 

================================================================

/perl/     找到含有 perl 的字符串

/^perl/    找到开头是 perl 的字符串

/perl$/    找到结尾是 perl 的字符串

/c|g|i/    找到含有 c 或 g 或 i 的字符串

/cg{2,4}i/ 找到 c 后面跟着 2个到 4个 g ,再跟着 i 的字符串

/cg{2,}i/  找到 c 后面跟着 2个以上 g ,再跟着 i 的字符串

/cg{2}i/   找到 c 后面跟着 2个 g,再跟着 i 的字符串

/cg*i/     找到 c 后面跟着 0个或多个 g ,再跟着 i 的字符串,如同/cg{0,1}i/

/cg+i/     找到 c 后面跟着一个以上 g,再跟着 i 的字符串,如同/cg{1,}i/

/cg?i/     找到 c 后面跟着 0个或是 1个 g ,再跟着 i 的字符串,如同/cg{0,1}i/

/c.i/      找到 c 后面跟着一个任意字符,再跟着 i 的字符串

/c..i/     找到 c 后面跟着二个任意字符,再跟着 i 的字符串

/[cgi]/    找到符合有这三个字符任意一个的字符串

/[^cgi]/   找到没有这三个字符中任意一个的字符串

/\d/       找寻符合数字的字符,可以使用/\d+/来表示一个或是多个数字组成的字符串

/\D/       找寻符合不是数字的字符,可以使用/\D+/来表示一个或是更多个非数字组成的字符串

/\*/       找寻符合 * 这个字符,因为 * 在常规表达式中有它的特殊意思,\来转义

/abc/i     找寻符合 abc 的字符串而且不考虑这些字符串的大小写

正则表达式的八大原则

如果在Unix中曾经使用过sed、awk、grep 这些命令的话,相信对于 Perl 语言中的正则表达式不会感到陌生。 Perl语言由于有这个功能,所以对字符串的处理能力非常强。在Perl语言的程序中,经常可以看到正则表达式的运用,在CGI程序设计中也不例外。

正则表达式是初学Perl的难点所在,不过只要一旦掌握其语法,你就可以拥有几乎无限的模式匹配能力,而且Perl 编程的大部分工作都是掌握常规表达式。下面给大家介绍几条正则表达式使用过程中的八大原则。

正则表达式在对付数据的战斗中可形成庞大的联盟——这常常是一场战争。我们要记住下面八条原则:

  • 原则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: 如果欲匹配不止一个字符集合,Perl使用 "|" 来增加灵活性。如果输入 m/(cat|dog)/ 则相当于“匹配字符串 cat 或者 dog。
  • 原则8: Perl用 (?..) 语法给正则表达式提供扩展功能。
时间: 2024-10-11 15:26:16

Perl 中的正则表达式的相关文章

perl学习之正则表达式

9    Perl 中的正则表达式 正则表达式的三种形式 正则表达式中的常用模式 正则表达式的 8 大原则 正则表达式是 Perl 语言的一大特色,也是 Perl 程序中的一点难点,不过如果大家能够很好的掌握他,就可以轻易地用正则表达式来完成字符串处理的任务,当然在 CGI 程序设计中就更能得心应手了.下面我们列出一些正则表达式书写时的一些基本语法规则. -----------------------------------------------------------------------

Perl中的正则表达

前几天用到了Perl语言,主要看了一下Perl中的正则表达式,在各种网页语言中,正则表达式在处理字符串的时候十分有用,所以这里就简单说一下在Perl中正则表达式的应用. 先上代码 1 #!/usr/bin/perl -w 2 #use utf8; 3 #use encoding "gb2312"; 4 5 open(DATA,"<test2.txt") or die "read error"; 6 7 open(OUT,">

JavaScript中的正则表达式(终结篇)

JavaScript中的正则表达式(终结篇) 在之前的几篇文章中,我们了解了正则表达式的基本语法,但那些语法不是针对于某一个特定语言的.这篇博文我们将通过下面几个部分来了解正则表达式在JavaScript中的使用: JavaScript对正则表达式的支持程度 支持正则表达式的RegExp类型 RegExp的实例属性 RegExp的实例方法 RegExp的构造函数属性 简单的应用 第一部分:JavaScript对正则表达式的支持程度 之前我介绍了正则表达式的基本语法,如果大家不是很了解可以先看下面

posix和perl标准的正则表达式区别

posix和perl标准的正则表达式区别; 正则表达式(Regular Expression,缩写为regexp,regex或regxp),又称正规表达式.正规表示式或常规表达式或 正规化表示法或正规表示法,是指一个用来描述或者匹配一系列符合某个句法规则的字符串的单个字符串 .在很多文本编辑器或其他工具里,正则表达式通常被用 来检索和/或替换那些符合某个模式的文本内容 .许多程序设计语言都支持利用正则表达式进行字符串操作.例如,在Perl中就内建了一个功能强大的在正则 表达式引擎.正则表达式这个

解析posix与perl标准的正则表达式区别 ---PHP

    正则表达式(Regular Expression,缩写为regexp,regex或regxp),又称正规表达式.正规表示式或常规表达式或正规化表示法或正规表示法,是指一个用 来描述或者匹配一系列符合某个句法规则的字符串的单个字符串.在很多文本编辑器或其他工具里,正则表达式通常被用来检索和/或替换那些符合某个模式的文本 内容.许多程序设计语言都支持利用正则表达式进行字符串操作.例如,在Perl中就内建了一个功能强大的在正则表达式引擎.正则表达式这个概念最初是由 Unix中的工具软件(例如s

PHP中有关正则表达式的函数集锦

之前学正则表达式的目的是想从网上抓取点小说啊,文档啊,还有获取相应的视频连接然后批量下载.当时初学PHP根本不知道PHP有专门抓包的工具,就像Simple_html_dom.php(在我的其他博文中有提到),之前根本就不知道有这东西,所以就自己废着劲去学习正则表达式,然后再学习PHP中正则表达式的函数是如何使用的,然后再分析自己要抓取的DOM,最后写自己的正则表达式,正则表达式,写着还可以,不过自己刚写完的正则表达式就可能看不出他是什么意思. 有种调侃正则表达式式的说法,把正则表达式叫做火星文.

JavaScript中使用正则表达式

      正则表达式又叫正规表示法,是一种表达文本模式的方法.通常是使用单个字符串来描述,匹配一系列符合某个规则的字符串.正则表达式是对字符串进行操作并且返回结果的一种工作方式,很多程序设计语言都对其进行了设计,而在JavaScript中对正则表达式的实现是基于perl的语法规则进行构建的.记得教我编程的老师说过“道士的驱魔符,医生的处方单,程序员的正则表达式”称为三个行业奇迹,表示非行业内的人很难弄懂到底是什么意思.其实正则表达式还是很容易入门的,但是要精通的话还是需要话一些时间的. 现在有

与Perl兼容的正则表达式函数

正则表达式不能独立使用,它只是一种用来定义字符串的规则模式,必须在相应的正则表达式函数中应用,才能实现对字符串的匹配.查找.替换及分割等操作.前面也介绍过在PHP中有两套正则表达式函数库,而使用与Perl兼容的正则表达式函数库的执行效率要略占优势,所以在本书中主要介绍以“preg_”开头的正则表达式函数.另外,在处理大量信息时,正则表达式函数会使速度大幅减慢,应当只在需要使用正则表达式解析比较复杂的字符串时才使用这些函数.如果要解析简单的表达式,还可以采用很多可以显著加快处理过程的预定义函数.下

grep、sed、awk、perl等对正则表达式的支持的差别

在各种常用的工具中, 正则表达式如此的相似却又不同. 下表列出了一些常用的正则表达式,以及其不同之处. 项目总多,遗漏必有不少,请各位看官不吝指出. 以perl的正则为基准,不同的用法以粉红色标出. grep 2.5.1 egrep 2.5.1 sed 3.02 sed 4.07 awk 3.1.1 perl 5.8.0 vim 6.1 JavaScript ?? 转义 \ \ \ \ \ \ \ 行头 ^ ^ ^ ^ ^ ^ ^ 行尾 $ $ $ $ $ $ $ n个 {n} {m,n} {m