PERL学习笔记---正则表达式

要匹配某个模式(正则表达式)和$_的关系,可以将模式放在正斜线(//)之间,如下:
$_ =“yabba dabba
doo”;
if(/abba/){
print “It matched!\n”;
}

表达式/abba/将在$_寻找这四个字母。如果找到,则返回true,在本例中,它出现了不止一次,但结果没什么不同。总之,
如果找到了,则匹配上;如果没找到,则没匹配上。
由于模式匹配通常返回true
或false,因此经常用在if 或while
的条件表达式部分。
所有在双引号中的转义字符在模式中均有效,因此你可以使用/coke\tsprite/来匹配11
个字符的字符串coke, tab(制表符),
sprite。

,点(.)是通配符,它可以匹配任何单个的字符,但不包括换行符(“\n”)。点(.)只匹配一个字符。、

反斜线是第二个元字符。如果需要真正的反斜线,需要重复使用两个反斜线。

。星号(*)表示匹配前一项0次或者多次。因此,/fred\t*barney/将匹配上fred
和barney
之间有任意个制表位(tab)的字符串。

如果希望包括不同的字符,怎么办呢?点(.)可以匹配任何单字符◆,因此.*将匹配任意字符任意多数。这就是说模式
/fred.*barney/将匹配fred,和barney
之间有任意多个任意字符(不含换行符)的字符串。任意行如果前面有fred,后面有barney,
其间为任意字符(字符串)都将匹配上。我们将.*叫做“任意字符串匹配模式”,因为任意的字符串均能被匹配上(不包括
换行符)。

星号的正是叫法是数量词(quantifier),意指其可以指代多个前面的项。它不是唯一的数量词,,加(+)也是。加(+)的意思是可
以匹配前面一项的一个或多个:/fred
+barney/意思是fred 和barney
之间由空格分开,且只能是空格。(空格不是元字符)。
它不会匹配fredbarney,因为加(+)意指一个或多个,因此至少是一个。可以这样看待加(+):“最后一项,(可选的)至少还
有一项。”

还有第三个数量词,其限制性更强。它是问号(?),其含义是前面一个项出现一次,或者不出现。也就是说,前面这个项出
现1
次或者0 次,此外不会有其它情况。因此,/barm-?bamm/只匹配:bamm-bamm
或bammbamm。这很容易记住:“前面
的这个项,出现?或者不出现?”

模式中的分组:括号也是元字符。在数学中,括号(())用来表示分组

选择符: 竖线(|),在这种用法中通常被读作“或(or)”,意思是匹配左边的或者右边的。如果竖线左边没有匹配上,则匹配右边。因
此,/fred|barney|betty/将匹配出现过fred,或者barney,或者betty
的字符串

/fred( |\t)+barney/这样的模式,它将匹配fred,barney
以及中间由空格,制表符(tab),或者二者混合所组
成的字符串

字符类的简写

有一些字符类出现的非常频繁,因此提供了其简写形式。例如,任何数字的类,[0-9],可以被简写为:\d。因此,HAL 这

个例子可以被写作/HAL-\d+/。
\w
被称作“word’字符:[A-Za-z0-9_]。如果你的“words”由通常的字母,数字,下划线组成,那你将非常喜欢它。通常认
为“word”由字母,连接符(-),撇号(‘)◆组成,我们希望能改变这种定义◆。因此使用它,请记住我们对“word”的定义,
字母,数字,下划线组成。
◆至少,在英语中是这样。在其它语言中,其words
由不同的符号组成。查看perllocale 的帮助手册了解更多的信息。
◆当查看ASCII
编码的英语文本时,我们遇到单引号和撇号(‘)是相同字符的问题,因此很难说cat’是cat 和一个撇号( ‘),还是cat
后接单引
号。这可能是计算机还不能接管世界的一个原因?。
当然,\w
不能匹配单词,而只能匹配单个字符。为了匹配整个单词,需要后接加号。模式/fred \w+
barney/将匹配fred,空
格,一个“单词(word)”,然后是空格和barney。因此,如果fred 和barney
之间有一个单词◆,由单个空格分隔开,它将
能匹配上。
◆我们将停止在word
上加引号;现在你已经知道其是由字母-数字-下划线组成的。
你可能已经注意到在前一例中,如果能更加灵活的匹配空白将很方便。\s
对于匹配空白(whitespace)将非常方便。它等价

于[\f\t\n\r ],其含5
个空白字符:格式符(form-feed);制表符(tab),换行符,回车,以及空格符。同其它简写符号一样,
\s
匹配此类中的单个字符,如果使用\s*将匹配任何个数的空白(包括没有),或者\s+匹配一个以上的空白(事实上,很少
见到单独使用\s,而不使用任何的数量词(*,
+))。由于这些空白符看起来类似,因此可以使用这种简写形式,将它们统一处
理。
 简写形式的补集
某些时候,你可能希望得到这三种简写形式的补集。如果那样的话,你可以使用[^\d],
[^\w], 和[^\s],其含义分别是,非数
字的字符,非word(记住我们对word
的定义)的字符,和非空白的字符。也可以使用它们对应的大写形式:\D, \W, \S

完成。它们将匹配它们对应的小写形式不能匹配上的字符。
这些简写形式可以在字符类中使用,或者在大的字符类中的中括号里面使用。也就是说你可以使用/[\dA-Fa-f]+/来匹配十六
进制(底为16)的数字,它将ABCDEF(或者其小写形式)作为附加的数字(11
到15)。
另一个类字符[\d\D],它的意思是任何数字,和任何非数字,则意指任何字符。这是匹配所有字符的一种通用方法,甚至包
括换行符,而点(.)匹配除换行符以外的任何字符。而[^\d\D]则完全没用,因为它匹配既非数字也非非数字的字符,那什么
也不是

时间: 2025-01-19 22:35:24

PERL学习笔记---正则表达式的相关文章

PERL学习笔记---正则表达式的应用

使用m//匹配 //这是m//(模式匹配)的一种简写.同qw//操作一样,可以使用任何成对的分隔符.因此,可以使用m(fred), m<fred>, m{fred}, m[fred],或者m,fred,, m!fred!, m^fred^,其它非成对的分隔符也可以 不区分大小写:/i if(/yes/i) {#大小写无关 print “In that case, I recommend that you go bowling.\n”;} 匹配任何字符:/s 默认情况下,点(.)不匹配换行符,这

Perl学习笔记(一)--简介

1. 查看当前所用Perl版本号 ? 1 perl –v 2.  一个简单的Perl程序 ? 1 2 3 print "hello world"; #这是注释 执行它: ? 1 Perl helloWorld.txt 文件名后缀可以是pl可以是txt 3. 一个稍微复杂点的Perl程序 ? 1 2 3 4 5 6 @line = `perldoc -u -f atan2`; //运行一个外部命令,通过反引号来调用,将输出结果一行行依次存储在@line这个数组变量中 foreach(@l

perl学习笔记--搭建开发环境

windows下perl开发环境搭建 perl下载地址:http://www.activestate.com/developer-tools 各个插件的安装方法:(通过代理上网的方法) 方法一:padwalker的安装步骤 1. padwalker下载地址: http://www.bribes.org/perl/ppm/ 2. 解压下载的文件 4. 拷贝 blib/lib/PadWalker.pm 到 Perl/lib(你的安装路径)5. 拷贝 blib/arch/auto/PadWalker

Python学习笔记——正则表达式

今天把之前学的正则表达式好好总结总结. 一.元字符 . :  .表示可以匹配任意一个字符 \d  :  \d表示可以匹配任意一个数字 \D  : \D表示可以匹配任意一个非数字 \s  :  \s表示可以匹配任意一个空白字母 \S : \S表示可以匹配任意一个非空白字母 \w : \w表示可以匹配任意一个字符 \W: \W表示可以匹配任意一个非字符 []  : []表示可以匹配括号中的任意的一个字符  例:[abc] , [a-z] , [^ab] ^  : ^表示只匹配字符串的开始部分    

perl学习笔记之:正则表达式

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

Perl 学习笔记-正则表达式

1.Perl中的正则表达式 在Perl中叫做模式, 是一个匹配(或不匹配)某字符串的模板, 是一种小程序, 对于一个字符串, 要么匹配, 要么不匹配. 使用简易模式: 将模式写在一对正斜线(/)中即可. 2.元字符  .  匹配非换行符 \n 的任何单字符, 需要注意的是转义字符如  \t  算做一个字符. 匹配  .  应该使用  \.  *  匹配前面的内容0次或多次, 使用  .* 表示匹配任意单字符任意次(这种模式也称为捡破烂模式)  +  匹配前面的内容至少1次  ?  匹配前面的内容

perl学习之正则表达式

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

PHP学习笔记-----正则表达式

正则表达式的语法规则 正则表达式描述了一种字符串匹配的模式,通过这个模式在特定的函数中对字符串进行匹配.查找.替换及分割等操作. 三个组成部分: 原子 元字符 模式修正符 以及         定界符 1 定界符 不仅局限"/".除了字母.数字和反斜线"\"以外的任何字符都可以作为定界符号. 2 原子 1       普通字符作为原子 a~z  A~Z 0~9 2  一些特殊字符和元字符作为原子 有特殊意义的符号,需使用转义字符"\" 3   一

Perl学习笔记(2)----正则表达式数字匹配的一个疏忽

<Perl语言入门>第15章习题第2题如下: 用 given-when 结构写一个程序,根据输入的数字,如果它能被3整除,就打印“Fizz”:如果它能被5整除,就打印“Bin”:如果它能被7整除,就打印“Sausage”.比如,如果输入15,程序就应该打印“Fizz”和“Bin”,因为15可以同时被3和5整除.思考一下,可以让程序输出“Fizz Bin Sausage”的最小数字该是多少? 自己写的程序如下: #!/usr/bin/perl 2 use 5.010; 3 my $num; 4