cdn perl_菜鸟教程perl总结

数据类型有:  标量$, 数组@,哈希%

数组声明 :  @hits= (25, 30, 40);  或者  @sites= qw/google taobao runoob/;

数组操作 pop, push, shift, unshif, splice(@ARRAY,OFFSET,LENGTH,LIST),   join, sort

合并数组, @numbers= (@odd, @even);  从列表中选择元素 @list= (5,4,3,2,1)[1..3];

哈希:   %data =('google'=>'google.com','runoob'=>'runoob.com','taobao'=>'taobao.com');

或者: %data =(-google=>'google.com',-runoob=>'runoob.com',-taobao=>'taobao.com');

判断元素是否存在, exists($data{'facebook'})

获取元素大小: $size= @keys; , 删除元素 delete$data{'taobao'};  增加元素 $data{'facebook'}= 'facebook.com';

foreach$a(@list) {print"a 的值为: $a\n";  }

运行符: =, +=, *=,%=,等 逻辑运行符  &&, ||, and, or, not, ++, --,  ('-' x 3) 输出为 ---

引号运算: q{abcd} 结果为 'abcd' , qq{abcd} 结果为 "abcd"

格式时间,获得当前时间:   use POSIXqw(strftime);    $datestring= strftime"%Y-%m-%d %H:%M:%S", localtime;

子程序(程序)

sub function { } 调用则是function();

参数:  子程序参数使用特殊数组 @_ 标明。因此子程序第一个参数为 $_[0], 第二个参数为 $_[1], 以此类推。

传递哈希:  当向子程序传递哈希表时,它将复制到 @_ 中,哈希表将被展开为键/值组合的列表。 my(%hash)= @_;   //转成哈希

返回值:  默认最后的值为返回值,  如果没有使用 return 语句,则子程序的最后一行语句将作为返回值

私有变量: my

临时变量 :  local,  我们可以使用 local 为全局变量提供临时的值,在退出作用域后将原来的值还回去

静态变量: state$count= 0; # 初始化变量,     不过在Perl中想要使用state必须在文件开头加上 use feature qw(state); 或者 use 5.010; 因为state功能是在5.010版本中才开始提供的。

perl引用

$scalarref =\$foo;# 标量变量引用

$arrayref =\@ARGV;# 列表的引用$hashref =\%ENV;# 哈希的引用$coderef =\&handler;# 子过程引用$globref =\*foo;# GLOB句柄引用

取消引用可以根据不同的类型使用 $, @ 或 % 来取消

perl格式化输出, 格式语法如下:

format FormatName=fieldline

value_one,value_two,value_three

fieldline

value_one,value_two

.

文件操作

open(DATA, "){print "$_";

}

模式描述

< 或 r

只读方式打开,将文件指针指向文件头。

> 或 w

写入方式打开,将文件指针指向文件头并将文件大小截为零。如果文件不存在则尝试创建之。

>> 或 a

写入方式打开,将文件指针指向文件末尾。如果文件不存在则尝试创建之。

+< 或 r+

读写方式打开,将文件指针指向文件头。

+> 或 w+

读写方式打开,将文件指针指向文件头并将文件大小截为零。如果文件不存在则尝试创建之。

+>> 或 a+

读写方式打开,将文件指针指向文件末尾。如果文件不存在则尝试创建之。

删除文件

unlink("/usr/runoob/test/file1.txt");

文件重命名rename ("/usr/runoob/test/file1.txt","/usr/runoob/test/file2.txt");

读入文件

$name = ;

print "网址:$name\n";

目录操作

#显示 /tmp 目录下所有以 .c 结尾的文件

$dir = "/tmp/*.c";@files = glob( $dir);foreach (@files){print $_ . "\n";

}

#显示 /tmp 和 /home 目录下的所有文件

$dir = "/tmp/* /home/*";@files = glob( $dir);foreach (@files){print $_ . "\n";

}

错误处理

die 函数类似于 warn, 但它会执行退出。一般用作错误信息的输出:

chdir('/etc') or die "无法切换目录";

warn 函数用于触发一个警告信息,不会有其他操作,输出到 STDERR(标准输出文件),通常用于给用户提示:

chdir('/etc') or warn "无法切换目录";

Carp 模块

在 Perl 脚本中,报告错误的常用方法是使用 warn() 或 die() 函数来报告或产生错误。而对于 Carp 模块,它可以对产生的消息提供额外级别的控制,尤其是在模块内部。

cluck() 与 warn() 类似,提供了从产生错误处的栈回溯追踪。

croak() 与 die() 一样,可以结束脚本。

confess() 与 die() 类似,但提供了从产生错误处的栈回溯追踪。

Perl 特殊变量

在迭代循环中,当前循环的字符串会放在 $_ 中, 然后 通过 print 输出。另外 print 在不指定输出变量,默认情况下使用的也是 $_。

$$ 运行当前Perl脚本程序的进程号

Perl 正则表达式

Perl的正则表达式的三种形式,分别是匹配,替换和转化:

匹配:m//(还可以简写为//,略去m)

替换:s///

转化:tr///

这三种形式一般都和 =~ 或 !~ 搭配使用, =~ 表示相匹配,!~ 表示不匹配。

$bar = "I am runoob site. welcome to runoob site.";if ($bar =~ /run/){print "第一次匹配\n";

}else{print "第一次不匹配\n";

}$bar = "run";if ($bar =~ /run/){print "第二次匹配\n";

}else{print "第二次不匹配\n";

}

替换, 例如我们将以下字符串的 "google" 替换为 "runoob": 格式如下:

s/PATTERN/REPLACEMENT/;

$string = "welcome to google site.";$string =~ s/google/runoob/;print "$string\n";

正则表达式变量

$`:匹配部分的前一部分字符串

$&:匹配的字符串

$':还没有匹配的剩余字符串

$string = "welcome to runoob site.";$string =~ m/run/;print "匹配前的字符串: $`\n";print "匹配的字符串: $&\n";print "匹配后的字符串: $'\n";

对象的创建和使用

subnew

{my $class = shift;my $self ={

_firstName=> shift,_lastName=> shift,_ssn=> shift,};#输出用户信息

print "名字:$self->{_firstName}\n";print "姓氏:$self->{_lastName}\n";print "编号:$self->{_ssn}\n";bless $self, $class;return $self;

}

使用创建的对象

$object = new Person( "小明", "王", 23234345);

Perl 里 类方法通过@ISA数组继承,这个数组里面包含其他包(类)的名字,变量的继承必须明确设定。

多继承就是这个@ISA数组包含多个类(包)名字。

Perl 包和模块

从一个包中访问另外一个包的变量,可通过" 包名 + 双冒号( :: ) + 变量名 " 的方式指定。

特殊变量 __PACKAGE__ 用于输出包名:

Perl语言提供了两个关键字:BEGIN,END。它们可以分别包含一组脚本,用于程序体运行前或者运行后的执行。

packageFoo;print "Begin 和 Block 实例\n";

BEGIN {print "这是 BEGIN 语句块\n"}

END {print "这是 END 语句块\n"}

Perl 模块是一个可重复使用的包,模块的名字与包名相同,定义的文件后缀为 .pm。

我们注意到 require 引用需要使用包名指定函数,而 use 不需要,二者的主要区别在于:

1、require用于载入module或perl程序(.pm后缀可以省略,但.pl必须有)

2、Perl use语句是编译时引入的,require是运行时引入的

3、Perl use引入模块的同时,也引入了模块的子模块。而require则不能引入,要在重新声明

4、USE是在当前默认的@INC里面去寻找,一旦模块不在@INC中的话,用USE是不可以引入的,但是require可以指定路径

5、USE引用模块时,如果模块名称中包含::双冒号,该双冒号将作为路径分隔符,相当于Unix下的/或者Windows下的\。 如: useMyDirectory::MyModule

特殊变量:

@_获得传得参数的值,$n= scalar(@_);可获得个数。

你可能感兴趣的:(cdn,perl)