`

Perl 的语法学习

    博客分类:
  • Perl
阅读更多

require 5.006
当版本号小于 5.006 的时候,会返回失败,从而导致模块加载失败。
所以它的作用就是保证模块调用环境的 Perl 版本。

our 和 my 一样,都是对变量的声明,
不过 our 声明的是包全局变量,
而 my 声明的是词法变量。

不过,经过 our 声明的变量,它会变得像一个词法变量一样,
其实这也是 our 存在的目的:用来欺骗 strict pragma,使 strict 以为它是一个词法变量,其实却不是。

有一个简单的办法可以理解 our:
1,你就把 our 声明的变量和 my 声明的当成一样。
2,记住 our 和 my 的区别:our 声明的是一个包全局变量,因此在符号表中存储(可以通过全限定在任何地方访问),而 my 声明的 是一个真正的词法变量,只能在闭合块中访问。

-------------------------------------


其实,our 的出现有它的历史,
Perl 和别的语言不同,可以随便声明变量,
在 Perl 4 那个时代,根本就不需要 my 什么的,
随便写个名字,就是变量了。
在 Perl 5 中仍然如此,除非你用 my 明确声明为词法变量,否则所有的变量都是(包)全局变量,而且可以不声明直接使用。
但是,这样有个坏处,那就是万一不小心写错名字了,或者解符号引用的时候,字符串运算错了,都会造成很多麻烦(因为按照 Perl 5 语法,这 些都是正确的,其结果就是产生一个新的变量,很显然,这不是你想要的目的。)

所以,为了解决这些问题,在 Perl 5 中就引入了 strict 和 warnings 两个 pragma,它们的作用,就是限制变量不 声明直接使用,
经过 strict 和 warnings 限制后,所有没有声明的直接使用的变量都会报错。但是 my 声明的变量又是局部变 量,local 又不能创造变量,
所以,我们就没法使用全局变量了(注1),
因此就又引入了 our,our 的作用就是声明一个全局变量,但是让 strict 和 warnings 以为它是词法变量,因 此 our 声明的变量也是词法作用域的。但是实际上它是全局变量。

注1:
如果不使用 our,我们有两种办法可以创建全局变量:
1,用 no strict "vars" 临时关掉 strict pragma,声明完了再用 use strict "vars" 打开。
2,用变量的全限定名称,如 $main::var 或者 $foo::bar 这样子。

 

声明:
以上提到的“全局变量”这个字眼都表示“包全局变量”。

------------------------

1 Perl 真假简单规则:

  数字 0 为假

  空的字符串(“”)和字符串“ 0 为假

  为定义值 undef 为假

  其他东西均为真

2 perl 相关控制语句学习

  Last’ :退出当前循环

  Next :使得控制权被重新传递到循环的顶部,同时下一循环继 续进行

  Exit Perl 退出语句

3 Perl 数据列表的三种表示方法:列表,数组与哈希结构

   Perl 中数组变量表示: @name

   qw 运算符: qw( apples oranges 45.6 $x) 等价于

              qw(‘apples’,’oranges’,’45.6’,’$x’)

   定义数组: @boy = qw(Greg Peter Bobby)

   print “@array”; 打印 @array 中的所有元素

   print scalar(@array) ;计算 @array 数组的元素数量

   (其中, scalar 是个特殊伪函数,强制参数在变量上下文中计算)

   注:在引用各个元素之前,数组不一定需要存在

   寻找数组结尾的两种方法:

   A :特殊变量,形式是 $#arrayname, 返回数组的最后一个有效索引的号码。

   B :在期望存在标量的位置上使用数组变量,如:

     $size = @array;

4 @foo=qw(water pepsi coke lemonade);

   $a = @foo;  //$a 包含数字 4

   $b= $#foo;  //$b 包含数字 3

   Print “$a\n”;

   Print “$b\n”;

5 :遍历数组:

    foreach $cone (@flavors)

    {

      Print “I’d like a cone of $cone\n”;

    }

   此代码中,变量 $cone 设置为 @flavors 中的各个值。

   注: foreach for 语句功能相同,互相之间可以替换使用。

6 数组与变量之间的转换:

    Split 函数:标量转换为数组

Join 函数:数组转换为变量

Split 函数格式:

Split 函数包含两个参数:第一个参数为模式,第二个为要分割的 标量。

sp @words=split(/ /,”the quick brown fox”)

注: @words 包含各个单词。

sp: $numbers=join(‘,’,(1.10));

注:将字符串 1 2 3 …10 赋予 $numbers

 

7 :数组排序函数介绍

   A sort() 函数

   B :飞船运算符 < = > :只能比较数字

   C cmp 运算符:比较字符串

8 reverse 函数

   功能:对字符串的字符进行倒序操作。

   Sp @liens=qw(I do not like greem eggs and ham);

       Print join(‘ ‘, reverse @lines);

9 Perl 的文件操作:

   打开句柄:

     Open (filename pathname) || die “$!”;

       成功返回一 个非 0 值,失败返回 undef (假)。其中 die 函数用于终止 perl 程序的运行。

   关闭文件句 柄:

     Close (filename);

   Perl 接 受反斜杠或正斜杠的 UNC 路径名, sp:

   open(MYTEXT,”c:\\windows\\users\\pierce\\novel.txt”)||die;

   open(MYTEXT,”c:/windows/users/pierce/novel.txt’)||die;

10 :读取文件:

    一用文件输 入运算符,二是尖括号运算符 <>

    sp:open(MYTEXT,”myfile”)|| die “can not open myfile:$!”;

      $line =<MYTEXT>;

     读取文件句柄的快捷方式是: while 循环。

    While <MYTEXT>

    {

       Print $_;

    }

注: while 循环负责吧输入行赋予 $_, 并确保文件结束,此种特性只有 while 循环才有。

   写入文件:

      Open(filename,”>pathname”)

      Open(filename,”>>pathname”)

     区别: > 告诉 perl pathname 设定的文件应该被用新数据改写,而现有数据被删除,同时 文件句柄是打开的,用于写入。

          >> 告诉 perl 打开该文件,新数据附加到该文件的结尾处。

    注:写入文 件后必须关闭文件句柄,写入的文件才生效。

 

11 :模式匹配

元字符是指改变模式匹配运行特性的字符。

简单匹配模式: m/ /

模式匹配的四个原则:

1) 匹配从目标字符串的左边开始,逐步向右边匹配

2) 当整个模式与目标字符串相匹配时,模式匹配才返回真

3) 目标字符串中第一个能匹配的字符串首先匹配

4) 进行第一次最大字符数量的匹配

 

12 :元字符简介:

   圆点 . :用于匹配除了换行符外的任何单个 字符。(单个不包括多个或 0 个)

        元字符前面加上 \, 元字符就可以纳入正则表达式。

   + 通配符:使前面的字符与后面的字符至少匹配一次 ,也可以匹配若干 次。

   * 通配符:使前面的字符可以进行 0 次或若干次匹配

   ?通配符:使前面的字符进行 0 次或一次匹配(最多匹配一次)

   {} 通配符,如: pat{n,m}, 其中, n 是最小匹配次数, m 是最大匹配次数。

注意:不能同时省略 n m

   .* 通配符:可以用来匹配任何东西。

    举例:模式 /c?ola/ 可以匹配 cola ola ,但是不能与 coola 匹配,多出的 c 需要匹配两次,模式 /c*ola/ 可以匹配 cola,ola ccola

 

13 perl 字符类:

   [] 将字符括起来,匹配时,字符类中的所有字符被视为单个字 符。

   如:【 abcde 】:用于匹配 a,b,c,d,e 中的任一字符

【A-        Za-z {5} :用于匹配任何一组 5 个字符

14 :位置通配符:

^ :位于开头的插入符号 ^ ,表示正则表达式只匹配一行开头的字符

$ :位于结尾的美元字符使模式只匹配一行结尾的字符

15 :替换运算符:

形式如下: s///. 语法如下:

S/searchpattrern/replacement/

替换运算符用于默认搜索 $_ ,找出 searchpattern ,用 replacement 来替换。

16 perl 程序

while ($line = <FILE>)

{

if ($line =~ /http:/)

{

print $line;

}

}

其中,=~符号是模式绑定 操作符,告诉 perl $line 中寻找匹配正则表达式 ”http:”

程序 2

next  LINE if $line =~ /^#/;

表示:当遇到#开头的行,则 跳到 LINE 循环的下一次循环。

17 perl 中常见的字母字符类型

名字    ASCII 代码    代码

空白      [\t\n\r\f]     \s

      [a-zA-Z_0-9]  \w

数字      [0-9]        \d

其中,这三个简写只匹配单个 字符。 可以用 \w+\ 来匹配一个单词。

如: /bam{2}/ :匹配 ”bam”

/(bam){2}/ :匹配 ”bambam”

18 :最小匹配

可以在量词后面加上一个问号 表示最小匹配。

如: /.*?:/: 此处的 .*? 现在表示尽可能少的匹配字符。

19 :模式修饰词

修饰词            含义

/i             忽略字符的大小写

/s             . 匹配换行符并忽略不建议使用的 $* 变量

/m            ^ $ 匹配下一个嵌入的 \n

/x             忽略大多数空白并允模式中的注释

/0             只编译模式一次

/g            全局地查找所有匹配

/cg           /g 匹配失败后允许继续查找

/e            把右边当作一个表达式来计算

应用举例: m/\w+:(\s+\w+)\s*\d+/;

  等价于:

  m

  {

  \w+;           # 匹配一个词和一个冒号

   {             # 分组开始

      \s+        #匹配一个或多个空白

      \w+       #匹配另一个单词

   }            #分组结束

   \s*           #匹配零或更多空白

   \d+           #匹配一些数字

}x;

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics