perl学习(3)模式匹配与正则表达式

时间:2022-02-08 07:06:01

一:模式匹配中的特殊字符

1:  点号 .

     匹配任何单个字符(换行符\n除外)

2:  反斜线 \

    转义字符,用于特殊符号前,使其失去特殊字符的作用变成普通字符

3:  +

    匹配该字符前面的字符(单个)至少一次;1次,2次...n次

4:  *

    匹配该字符前面的字符任意次:0次,1次...n次

5:  ?

    匹配该字符前面的字符0次或者一次

6:  .*

    匹配任意字符任意次(换行符除外)

7:  {count}

    匹配前面的字符count次

8:  {min,}

    匹配前面的字符至少min次

9:  {min,max}

    匹配至少min,至多max

10:  *?

    匹配该字符前面的字符任意次:0次,1次...n次,倾向于短字符,非贪婪量词

11:  +?

    匹配该字符前面的字符(单个)至少一次;1次,2次...n次,倾向于短字符,非贪婪量词

12:  ()

    模式分组字符 eg:/(perl)+/  #有()匹配模式是perl,没有括号,匹配模式是单个字符l;

    1)借助模式分组,可以使用\number的方向引用来引用括号内匹配的内容,n和括号内的组号匹配

    perl学习(3)模式匹配与正则表达式

    2)perl 5.10可以使用\g{number}这种形式的反向引用,n可以为负数

    perl学习(3)模式匹配与正则表达式

              输出:perl学习(3)模式匹配与正则表达式

13:  |

    或,即匹配左右都可

14:  例子

    perl学习(3)模式匹配与正则表达式

             输出:perl学习(3)模式匹配与正则表达式

 二:  字符集

   字符集是指一串可能出现的字符集合。通过写在方括号([ ])内来表示。只能用来匹配单个字符,但可以是方括号内列出的任意一个   

     perl学习(3)模式匹配与正则表达式

              输出:perl学习(3)模式匹配与正则表达式

1:  可以使用字符 - 进行简写; [0-9]表示0到9十个数字

2:  可以使用脱字符 ^ 匹配字符集外的字符

3:  字符集简写

    perl学习(3)模式匹配与正则表达式

    说明:\d 匹配任意的数字, \w匹配任意的字母数字下划线 ,\s匹配任意的空格,

     perl学习(3)模式匹配与正则表达式

4:  例子

    perl学习(3)模式匹配与正则表达式

              输出:perl学习(3)模式匹配与正则表达式

    问题:test_id = 20010的\w\s+匹配一个字符多个空格;按道理匹配不了啊,但输出匹配成功

5:  常用字符集

    /[\dA-Fa-f]+/   :匹配16进制数

    /\d\D/              :匹配任意字符

    /^\d\D/            :什么字符都不匹配

四:  模式匹配操作符与修饰符

1:   操作符

      在前面的介绍与例子中,我们使用 // 来进行匹配(实际上是m//);

    模式匹配操作符可以使用任意成对的定界符,当使用斜线作为定界符时,开头的m可以省略

    eg:m(fred),m<fred>,m{fred},m[fred]

      m%http://% 

2:  修饰符(在操作符后面,其实与操作符的/符号合用)

    1)/i  

     进行模式匹配时,将不区分大小写

    2)/s

    模式中的点号将匹配包括换行符在内的任意字符(注意与\s区分开来,\s是字符集里匹配任意的空格的简写)

    3)/x

    忽略空白符,使用/x修饰符可以在模式里面随意加上空白,使其更容易阅读。

五:  锚位

1:  ^

     标志字符串的开头

2:  $

    标志字符串的末尾,eg:/^\s*$/

3:    /b 指定特定的单词

    单词(\w+)锚位,匹配任何单词的收尾

4:  /B

    非单词锚位,匹配所有/b不能匹配的位置

 5:  例子

    perl学习(3)模式匹配与正则表达式

               输出:perl学习(3)模式匹配与正则表达式

六:  绑定操作符=~

    默认情况下,模式匹配的对象的$_,绑定操作符=~用于告诉perl拿右边的模式匹配左边的字符串,而不是匹配$_变量中的字符串

     perl学习(3)模式匹配与正则表达式

七:  模式串中的变量内插

    例如:

    my $val = "just";

    my $val2 = "This is just a test example";

    if ($val2 =~ /($val)/) { .... } #正则表达式中的变量内插,if ($val2 =~ /$(val)/)也可。

八:  捕获

    把圆括号内的字符串暂时记忆下来的能力,如果有多个圆括号,就有多个捕获。捕获变量都是标量变量,依次为$1,$2...$n

1:   捕获周期

    捕获变量通常能存活到下次成功的模式匹配为止,即失败的匹配不会改动上次工程匹配时捕获的内容,而成功时会将它们重置。如果在数行之外使用捕获变量,最好将捕获变量的值复                      制到一个一般的变量里 

     perl学习(3)模式匹配与正则表达式

                输出:perl学习(3)模式匹配与正则表达式

2:  不匹配模式

    一般情况下,模式使用的圆括号都会捕获部分的匹配串到捕获变量中,但若perl正则表达式允许使用括号但不做捕获(不捕获括号),需要在左括号的后面加上问号和冒号(?:)。

3:   命名捕获

    管理$1,$2...是比较困难的,尤其是对比较复杂的正则表达式而言。Perl5.10引入了正则表达式命名捕获的概念。

    在命名捕获中,捕获结果保存在%+的特殊哈希中;模式加标签的写法是(?<LABEL>PATTERN),访问为$+{LABEL},可使用\g{LABEL}或\k{LABEL}反向引用。

  例子:

    perl学习(3)模式匹配与正则表达式

                 输出:perl学习(3)模式匹配与正则表达式

 4:  自动匹配变量

    $&:匹配括号的内容;$`:匹配内容前的字符;$’:匹配内容后的值(包括空格逗号等)

 

 九:  替换

1:  s///

    前两个//里是要替换的字符,后两个//里是替换的字符;返回布尔值,替换成功时为真;只替换一个值

2:  /g

    全局替换;常写在s///后面,/g的斜线省略

    perl学习(3)模式匹配与正则表达式

    输出:

    perl学习(3)模式匹配与正则表达式

3:  不同的替换界定符

    和m//一样,s///操作符也可以使用其他的定界符

    1)使用没有左右之分的非成对符号,跟s///一样,只需重复三次即可;eg:s#Barney#Fred#

    2)使用有左右之分的成对符号,必须使用两对,一对圈引模式,一对圈引替换模式。圈引模式与圈引替换模式不一定要相同

    eg:s{barney}{fred};s[barney][fred];s<fred>#barney#

4:     替换修饰符 

     /g(全局替换)

     /i,/s,/x (四(2)同)

     /m 使模式匹配字符串内的换行符

5:  大小写转换

    perl学习(3)模式匹配与正则表达式

    例子:

    perl学习(3)模式匹配与正则表达式

               输出:perl学习(3)模式匹配与正则表达式

 十:  split操作符

    根据指定的分隔符拆开一个字符串,返回子串的列表(即将一个字符串分解为多个)。尤其适用于处理被制表符,冒号,空白或其他符号分割的数据

1:  语法规则

    @split = split /separator/,$string    or @split = split( /separator/,$string)

    split会保留开头处的空字段,并省略结尾处的空字段

2:  例子

     perl学习(3)模式匹配与正则表达式

                  输出:perl学习(3)模式匹配与正则表达式

    说明:多余的冒号会被当成空字符

十一:  join函数

     将多个字符串片段合并成一个字符串

        my $result = join $glue,@pieces; or my $result = join ($glue,@pieces)

       perl学习(3)模式匹配与正则表达式

                   输出:perl学习(3)模式匹配与正则表达式

十二:  列表上下文中的m//

     一般情况下,模式匹配操作符m//返回的是布尔值,如果在列表上下文中使用模式匹配操作符,将返回所有捕获变量的列表

      eg:my $test = "hello,there,neighbor";

        my ($first,$second,$third) = ($test = ~ /(\S+) (S+), (S+)/); 大写S是小写s补集。

十三:  命令行执行perl

      perl -p -i.bak -w -e  's/Randall/Randal/g'  fred*.dat

       perl学习(3)模式匹配与正则表达式

十四:debug perl脚本

    1)在程序头添加-d或者在终端perl -d filename.pl;打开debug模式

    2)DB<1>       l :list the next few lines;p $variable name: 输出变量值;  q:quit;  

            r:从子函数中返回;      R:再次运行;    n:单步执行,不进入子函数(F10)

            s:单步执行(F11),进入子函数;

            b:放断点,如b 20 在第二十行放断点 ;   c:运行到第一个断点处