|
<br>8 Perl 的简单语法(与 C 语言的异同)<br>基本输入输出 <br><br>分支循环控制结构 <br><br>函数 <br><br>常用系统调用 <br><br>文件操作 <br><br>进程管理 <br><br>7.1 基本输入输出<br>在 BASH 脚本程序中,我们用 read var 来实现从键盘的输入,用 echo $var 来实现输出。那么在 Perl 中将有一点变化。Perl 中将标准输入用关键词 <STDIN> 表示;标准输出用 <STDOUT> 表示,标准错误输出用 <STDERR> 表示。故而从标准输入读取数据可以写成:<br><br>$var=<STDIN>; # 读取一行输入,并存入变量 $var 中。<br>@var=<STDIN>; # 读取多行输入,并存入数组 @var 中。<br><br>在 Perl 语言中,变量 $_ 是许多操作符的缺省变量。因此如果需要读入许多行并对每行分别处理一般这样写:<br><br> while($_=){ <br> chop($_); # chop 调用用于去掉 $_ 变量中的最后一个字符(换行符)。<br> # 处理$_(每一行)<br> } <br><br>或者可以简写为:<br><br> while(){ <br> chop; # 等同于chop($_) <br> # 处理$_(每一行) <br> }<br><br>如果 <> 括号之间没有任何字符,则表示从命令行所指示的文件中读取数据,看下面这个例子(read.pl):<br><br> #!/usr/bin/perl; <br><br> while(<>){ <br> print $_; <br> }<br><br>如果在命令行输入 $ perl read.pl read.pl 。这个程序将在屏幕上打印出文件 read.pl 的每一行。<br><br>在前面的例子中我们已经看见,Perl 语言中向标准输出输出数据可以用 print 语句。我们在 print 语句中可以输出多个变量,变量之间用 "," 分隔开来。如下面的例子:<br><br> print 3,45*2,"hello",2+2;<br><br>上面的输出语句将给出 "390hello4" 的输出结果。<br><br>除了 print 语句以外,Perl 中还提供了一个 printf 语句用于标准输出,不过 printf 更接近于 C 语言的 printf 函数,可以进行格式化的输出,如:<br><br> printf "%10s% 8d%8.2f\n",$a,$b,$c;<br> printf("%10s% 8d%8.2f\n",$a,$b,$c); # 加上括号的 C 语言写法也是可以的。<br><br><br>另外 print 和 printf 在输出数组变量的时候也是不同的,如下例:<br><br>@a = (1 , 2, 3); <br>printf @a; <br>print "\n"; <br>print @a; <br>print "\n";<br><br>输出的结果是:<br><br>1<br>123<br><br>如果在 @a 两边加上 "" ,则输出就都是 123了。<br><br> <br><br>7.2 分支循环控制结构<br>if 语法<br>erl 语言的 if...then...else... 语句结构和 C 语言非常相似,该结构一共有三种变种,分别如下:<br><br>if 语法 1:<br><br>if(判别运算式)<br>{ <br> 表达式为真时的语句块; <br>}<br><br>或写成:表达式为真时的语句 if (判别运算式);<br><br>实例为:print "您的分数及格了!\n" if ($score>=60);<br><br>if 语法 2:<br><br>if(判别运算式一){ <br> 判别式一为真时的语句块;<br>}else{ <br> 判别式一为假时的语句块;<br>}<br><br>if 语法 3:<br><br>if (判别运算式一)<br>{ <br> 判别式一为真时的语句块;<br>}elsif(判别运算式二){ <br> 判别式二为真时的语句块;<br>}elsif(判别运算式三){ <br> 判别式三为真时的语句块;<br>}else{ <br> 所有判别式为假时的语句块;<br>}<br><br>unless 语法<br>unless的含义就是说“如果判别式不为真,就执行...”。<br><br>unless 语法 1:<br><br>unless(判别运算式) { <br> 判别式为假时语句块;<br>}<br><br>或写为:判别式为假时语句 unless (判别运算式);<br><br><br>unless 语法 2:<br><br>unless(判别运算式)<br>{<br> 判别式为假时语句块;<br>}else{ <br> 判别式为真时语句块;<br>}<br><br>进阶技巧:"&&"、"||" 及 "? :" <br>这些符号看上去像标点符号,或是表达式的一部分。和 C 语言中一样,他们在 Perl 语言中也可作为控制结构,而且更简洁,只是可读性差了很多。 <br><br>比如说:<br><br> if (判别表达式) {为真时语句块};<br><br>也可以写为:<br><br> 判别表达式 && 为真时的语句块 <br><br><br>同样道理,unless(this){that} 可替换为 this||that。<br><br>? : 则可以这样使用:<br><br>exp1?exp2:exp3<br><br>这个式子表示:如果 exp1 为真则求 exp2 的值,否则求 exp3 的值。<br><br>while 循环语法<br>erl 语言中 while, do...while, for, until, foreach 均可以用于实现循环结构,循环中还可以用 last,next,redo 等操作符进行控制。下面我们先介绍 while 语法。<br><br>while(判别运算式) { <br> 程序叙述区块;<br>}<br><br>上个语法在Perl中也可以写成: 程序叙述区块 while(判别运算式);<br><br>do...while 循环语法<br>do<br>{ <br> 程序叙述区块;<br>}while(判别运算式);<br><br><br>在 while 和 do while 循环最大的区别是在 do while 循环中,循环体至少会被执行一次。<br><br>until 循环语法<br>until(判别运算式)<br>{ <br> 程序叙述区块;<br>}<br><br>上个语法在Perl中也可以写成: 程序叙述区块 until (判别运算式);<br><br>do...until 循环语法<br>do{ <br> 程序叙述区块; <br>}until (判别运算式);<br><br>for 循环语法<br>for (初始化运算式;判别运算式;循环过程运算式)<br>{ <br> 程序叙述区块;<br>}<br><br>或者<br><br>for $variable(@array)<br>{ <br> 程序叙述区块;<br>}<br><br><br>第二个语法中如果把 $variable 变量省略的话,就会将数组 @array 的元素一个一个指定给 $_ 这个变量,这是比较精简的写法。其中第一个语法更接近于 C 语言的语法。<br><br>foreach 循环语法<br>foreach $variable(@array)<br>{ <br> 程序叙述区块;<br>}<br><br>如果把$variable变量省略的话,就会将数组@array的元素一一指定给$_这个内定的输出变量.<br><br>last 退出循环语法<br>范例:<br><br>for($i=1;$i<=10;$i++)<br>{ <br> last if ($i==5); # 如果 $i 等于5的话就退出 for 循环<br> print"$i\n";<br>}<br><br>next 继续循环语法<br>范例:<br><br>for($i<=10;$i++)<br>{ <br> # 如果是 2 的倍数的话,就到循环的下一个陈述<br> next if($i%2)==0)<br> print"$i是一个奇数!\n";<br>}<br><br> <br><br><br><br><br>7.3 函数<br>erl 语言中有两种函数,一种是 Perl 自带的一些实用系统函数,如文件打开函数 open 等;另一种是用户自定义的函数,用户通过自己定义函数可以使得程序的结构化更加清晰。<br><br>用户函数又称子程序(Subroutine),在 Perl 中用下面的结构来定义用户函数:<br><br> sub 子程序名{<br> 语句块;<br> }<br><br>这里的子程序名与变量的取名规则类似。<br><br>与 BASH 程序不同,Perl 中的用户函数的定义可以位于程序的任何位置,比如说放在文件的未尾,而并不需要放在调用该函数的代码之前。如果两个子程序使用了相同的程序名,位置靠后的子程序将覆盖前面子程序。<br><br>需要注意的是用户函数中的变量默认为全局变量,并不是像 C 语言中那样是局部变量,Perl 函数中的变量可以被其他程序段共享。如果希望定义局部变量,可以用下面两种方法来实现: <br><br>local($a);<br>my $a;<br><br>另外用户函数的调用:通过在子程序前加“&”符号才可以,函数可在任一表达式内被调用。函数调用可以嵌套,即子程序中可以再调用另外的子程序,即可以程序员可以用 Perl 写出具有递归特性的代码。<br><br>调用用户函数产生的结果称为返回值(return value)。返回值是每次函数被执行时,最后一个被执行到的表达式的计算结果。如: <br><br>sub add_a_b{<br> $a+$b;<br>}<br><br>函数最后一条表达式为 $a+$b,故返回值为 $a+$b 的计算结果。以下是调用情况:<br><br>$a = 5;<br>$b = 6;<br>$c = &add_a_b; # $c 的值为 11<br>$d = 5 * &add_a_b; # $d 的值为 5*11,即 55<br><br>还有一个问题是,在 Perl 程序中如何向函数中传递参数呢?这是可以实现的,调用函数时,可以将参数依次放在函数名后面的 "()" 中,而在函数体中,系统默认数组 @_ 中就按同样顺序存放着所有的参数。我们可以访问 @_ 变量,从而确定参数的个数及其数值。<br><br>仍以加法函数为例:<br><br>sub add_a_b{<br> $_[0]+$_[1];<br>}<br><br>$c=&add_a_b(5,6); #$c的值为11<br>$d=5*&add_a_b(2,3); #d的值为5*5即25<br><br>更为奇特的是,这种方式可以实现变参数传递,即参数个数不确定的传递。C 语言也可以实现这种传递,如我们熟悉的 printf 函数,只是他们的实现机制不太一样,C 更深奥一些,此处就不多解释了。 <br><br>sub add_all{<br> $sum=0; #将sum初始化<br>foreach $_(@_) { #遍历参数列表<br> $sum+=$_; #累加每个元素<br>}<br> $sum; #返回sum即总和的值<br>}<br><br>$a=&add_all(3,4,5); #$a的值为3+4+5即12<br>$d=2*&add_all(1,2,3,4,5); #d的值为2*15即30<br><br><br><br><br><br>7.4 常用系统调用<br>下面将介绍一些 Perl 自身提供的一些标准系统函数,这些函数包括: print 、printf 、chop 、split 、keys 、values 、reverse 、sort 、length 、substr 、index 、push 、pop 、unshift 、shift 、join 、grep 、hex 、rand 、localtime 、die 、open 、close 、pack 、read 、exit。下面就来分别介绍他们。 <br><br> <br><br><br>--------------------------------------------------------------------------------<br><br>指令:print<br>语法:print Filehandle LIST<br>说明:这个 Filehandle 可以看作在 I(INPUT)/O(OUTPUT) 之间的一个桥梁,可以利用 FILEHANDLE 来做出数据读入写出的动作。STDIN 是代表从哪里输入数据,例如从电脑的键盘输入;STDOUT是代表从哪里输出数据,例如从电脑的屏幕输出;STDERR 是代表从哪里输出错误的数据,例如从电脑的屏幕输出。而在PERL语言中有三个标准FILEHANDLE: <br>1. STDIN(标准输入):是代表 STDIN 的 FILEHANDLE <br>2. STDOUT(标准输出):是代表 STDOUT 的 FILEHANDLE <br>3. STDERR(标准错误输出):是代表 STDERR 的 FILEHANDLE <br>如果要使用其他 FILEHANDLE 的时候,就要先用 OPEN 这个函数来打开一个 FILEHANDLE,我们可以用 PRINT 这个函数将 LIST 中的数据输出给 FILEHANDLE。<br><br> 语法: print LIST <br>说明: 如果省略 Filehandle 的话,就会把 Filehandle 默认为 STDOUT。也就是会将 LIST 的数据内容显示在终端屏幕上。<br><br>语法: print<br>说明: 同时省略 Filehandle 和 LIST 的话,就会以 STDOUT 为 Filehandle,并会输出 $_ 这个系统内部变量的数据内容。如果 $_ 变量是一个空字符串的话,就会显示出一个空字符串。<br><br><br><br>--------------------------------------------------------------------------------<br><br>指令: printf<br>语法: printf Filehandle LIST<br>说明: 在 Perl 语言中也提代 C 语言中 printf 的语法,用法和 C 语言中的用法一模一样。如果把 Filehandle 省略的话,也一样会把 STDOUT 当成是默认的 Filehandle。<br>示例:<br><br>printf("chomod %d %s\n","711""cgi"); 会将chmod 711 cgi加上换行显示于屏幕上。 <br><br><br>--------------------------------------------------------------------------------<br><br>指令:chop 语法:chop($url)<br>说明:把最后一个字符删除。<br>示例:<br>$url="www.aka.org.cn/; chop($url); <br>这时$url="www.aka.org.cn" 还可以简写成 chop($url="www.aka.org.cn/"); chop 函数一般用于去掉从键盘读入数据中的最后一个换行符。<br><br><br>--------------------------------------------------------------------------------<br><br>指令:split<br>语法:split(/pattern/,$text,limit) 其中/pattern/是文字处理的模式,而limit是代表要分割的个数,一般可以省略。<br>说明:用一个指定的文字处理模式来分割 $text 字符串。<br>示例:<br>$text="Michael,Gevin,Mike"; @name=split(/,/,$text); # 这时 @name=("Michael","Gevin","Mike"); <br>@name=split(/,/,$text,2); # 这时 @name=("Michael","Gevin");<br>在传送CGI应用程序数据的时候会先将数据编码,其中会将FORM中第个数据字段 的数据内容用&这个符号隔开,所以在解码的时候就要以 "&" 这个符号为分割的字符,将每个数据字段分割出。而数据字段的名称和这个数据字段的值是用=这个符号来隔开,如果想取得数据字段的名称和所对应的值的话,就用要 "=" 这个符号来分割数据字段,<br><br><br>--------------------------------------------------------------------------------<br><br>指令:keys<br>语法:keys(%array)<br>说明:取出关联数组 %ARRAY 中全部的 key。<br>示例:<br>%NAME=(1,"mike",2,"michael"); @readkey=keys(%NAMES); # 这时 @readkey=(1,2); <br><br><br>--------------------------------------------------------------------------------<br><br>指令:values<br>语法:values(%array)<br>说明:取出关联数组 %ARRAY 中全部的 value。<br>示例:<br>%NAMES=(1,"mike",2,"michael"); @readval=values(%NAMES); #这时 @readval=("mike","michael"); <br><br><br>--------------------------------------------------------------------------------<br><br>指令:reverse<br>语法:reverse(@array)<br>说明:将数组 @array 中的元素由后到前重新排列。<br>示例:<br>@back=("A","B","C","D","E"); @back=reverse(@back); # 这时 @back=("E","D","C","B","A"); <br><br><br>--------------------------------------------------------------------------------<br><br>指令:sort<br>语法:sort(@array)<br>说明:将数组中的元素由小到大排序,如果要由大到小排序的话,要加上reverse这个函数。<br>示例:<br>@abc=("d","b","c","a"); @abc=sort(@abc); # 这时 @abc=("a","b","c","d");<br>@abc=(reverse sort@abc); # 这时@abc=("d","c","b","a"); 这个语法也可以写成 @abc=(reverse sort(@abc));<br>@number=(5,2,10); @number=sort(@number); <br># 上面示例用sort函数来排序数值的时,会出差错,因此要用下面到下面这一句。 <br>@number=(sort{$a<=>$b}@number); # 这时 @number=(2,5,10); <br><br><br>--------------------------------------------------------------------------------<br><br>指令:length<br>语法:length($string)<br>说明:求出字符串$string的字节(bytes)值。<br>示例:<br>$string="erl5"; $size=length($string); # 这时 $size=5; <br><br><br>--------------------------------------------------------------------------------<br><br>指令:substr<br>语法:substr($string,offset,length) offset代表起始字符的位置,length代表引用的字符串长度,如果省略length则代表从起始值到字符串的最后一个字符长度。而offset如果是负值的话,就会从字符串右边开始指定字符。<br>示例:<br>$s=substr("perl5",2,2); # 这时 $s="rl";<br>$s=substr("perl5",2); # 这时 $s="rl5";<br>$s=substr("perl5",-2,2); # 这时 $s="er"; <br><br><br>--------------------------------------------------------------------------------<br><br>指令:index<br>语法:index($string,$substring,position) $substring是要寻找的字符;position代表从哪一个位置开始寻找,假如省略position就从头开始找起。<br>说明:返回所要找寻的字符在一字符串$string中的位置,如果在字符串中找不到字符的话,则会返回-1这个 值。<br>示例:<br>$s=index("perl5","p"); # 这时 $s=0<br>$s=index("perl5","l",2); # 这时 $s=3<br>$s=index("perl5","perl"); # 这时 $s=-1 <br><br><br>--------------------------------------------------------------------------------<br><br>指令:push<br>语法:push(@array,$string)<br>说明:在数组@array的最后附加新的元素 ($string)到数组@array中。<br>示例:<br>@array=("one","two"); push(@array,"three"); # 这时 @array=("one","two","three") <br><br><br>--------------------------------------------------------------------------------<br><br>指令:pop<br>语法:pop(@array)<br>说明:将数组(@array)的最后一个元素删除,并将删除的元素返回。<br>示例:<br>@array=("one","two"); $rm=pop(@array); # 这时 @array=("one");而$rm="two"; <br><br><br>--------------------------------------------------------------------------------<br><br>指令:unshift<br>语法:unshift(@array,$string) <br>说明:在数组@array的第一个元素前附加新的元素$string到数组@array中。 <br>示例:<br>@array=("one","two"); unshift(@array,"three"); # 这时 @array=("three","one","two") <br><br><br>--------------------------------------------------------------------------------<br><br>指令:shift<br>语法:shift(@array)<br>说明:将数组@array的第一个元素删除,并将删除的元素返回。<br>示例:<br>@array=("one","two"); @rm=shift(@array); # 这时 @array=("two");而$rm="one"; <br><br><br>--------------------------------------------------------------------------------<br><br>指令:join<br>语法:join($string,@array)<br>说明:在一数组@array的元素之间加上一指定的字符$string,并将结果返回。<br>示例:<br>@array=("one","two","three");<br>$total=join(":",@array); 这时 $total="one:two:three"; <br><br><br>--------------------------------------------------------------------------------<br><br>指令:grep<br>语法:grep(/pattern/,@array)<br>说明:将合文字处理模式(regular expression)的数组元素找出来。<br>示例:<br>@array=("one","on","in");<br>$count=grep(/on/,@array); # 这时 $count=2<br>@result=grep(/on/,@array); # 这时 @result=("one","on"); <br><br><br>--------------------------------------------------------------------------------<br><br>指令:hex<br>语法:hex($string)<br>说明:将十六进制的数值转成十进制。<br>示例:<br>$decimal=hex("ff"); 这时 $decimal=255; <br><br><br>--------------------------------------------------------------------------------<br><br>指令:rand<br>语法:rand($interger)<br>说明:常和函数srand搭配来取得一随机数,如果没有先宣告stand函数的话,则取出的常数值是一个固定值。这个语法会返回一个介于 0 和$interger之间的数值,如果$interger省略的话,则会返回一个介于 0 和 1 的数值。<br>示例:<br>srand; # 要先调用一次srand函数,才能产生随机数的效果<br>$int=rand(10); # $int的值会大于 0 而且小于 10 ,如果希望产生的乱数是整数的话,就要再加上int 这个函数,如下<br>$int=int(rand(10)); # $int的值是一个整数,且值在 0 和 9 之间 <br><br><br>--------------------------------------------------------------------------------<br><br>指令:localtime<br>语法:localtime(time)<br>说明:可返回九个有关时间的元素,在写CGI应用程序的时候常会用到系统的时间,所以在此会详细介绍这个函数的用法。<br>示例: <br>($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst)=localtime(time); <br>其中: $sec 代表秒数 [0,59]、$min 代表分数 [0,59]、$hour 代表小时数 [0,23]、$mday 代表是在这个月的第几天 [1,31]、$mon 代表月数 [0,11] 因此要将 $mon 加 1 之后,才能符合实际情况、$year 从 1990 年算起的年数、$wday 从星期六算起,代表是在这周中的第几天 [0-6]、$yday 从一月一日算起,代表是在这年中的第几天 [0,366]、$isdst 只是一个 flag 知道这些变量之后,就可以在 CGI 应用程序中拿来应用了。<br>此外,也可以用下面这一行指令在 UNIX 系统下取得系统的时间。为了避免错误发生,最好用绝对路径的方法来取得系统时间,如果绝对路径不清楚的话可以用 "which data" 这个指令来得知。$data='/usr/bin/data'; 而在 Perl 5 版本中,也可以用下面这一行指令来取得系统时间。 $data=localtime(time); <br><br><br>--------------------------------------------------------------------------------<br><br>指令:die<br>语法:die LIST<br>说明:会把LIST字符串显示出来,并退出程序。常常和 $! 这个代表错误信息变量一起使用。<br>示例:<br>open(FILE,"$filename")||die "不能打开文件$!\n; # 如果打开文件失败的话,就会显示出错误的信息,之后再退出程序。 <br><br><br>--------------------------------------------------------------------------------<br><br>指令:open<br>语法1:open(filehandle,"$filename") 其中 $filename 是一个指定打开的文件名。<br>说明:这是一个很常用的函数,可用于文件的打开(read only)。<br>示例:<br>$filename="usr/abc.txt";<br>open(FILE,"$filename")||die"不能打开文件$filename\n; #将&ltfile>数据指定给纯变量$line(一行一行地)<br>while($line=<FILE>)<br>{<br>print"$line";<br>}<br>close(file); 就会把abc.txt这个文件的内容显示出来。<br><br>语法2:open(filehandle,"<$filename")<br>说明:这个语法也可以打开一个存在的文件(read only)。<br>示例:<br>$filesname="usr/abc.txt";<br>open(file,"<$filename")||die"不能打开文件$filename\n";<br>@array=&ltfile> # 将 <FILE> 全部的数据内容都指定给数组 @array <br>close(file);<br>print "@array"; # 也会把abc.TXT这个文件的内容显示出来。<br><br>语法3:open(filehandle,">$filename")<br>说明:建立一个新的文件(write only);如果已经存在这个文件了,就会把旧文件名覆盖掉。并可用print filehandle的方式将数据存入打开的文件中。<br>示例:<br>$filename="/usr/abc.txt";<br>open(file,">$filename")||die"不能打开文件$filename\n;<br>print file "this is a new line1\n; # \n是换行字符<br>print file "this is a new line2\n;<br>close(file); # 会将数据存在一个新文件中。<br><br>语法4:open(filehandle,">>$filename")<br>说明:数据用附加的方式定入一文件(write only),如果指定的文件名不存在的话就会建立一个新的文件。<br>示例:<br>$filename="/path/abc.txt";<br>open(file,">>$filename")||die"不能打开文件$filename\n";<br>print file "this is a new line1\n";<br>print file "this is a new line2\n";<br>close(file); # 会打数据附加(append)到一个文件(abc.txt)中。<br><br>语法5:open(filehandle,"|unix command")<br>说明:就会把在filehandle的数据输入给unix的指令来作处理。<br>示例:<br>$mailprog="/usr/ucb/mail"; # unix系统上的寄信程序(一定要加绝对路径)<br>$who="mqingyi@126.com";<br>$open(file,"|$mailprog$who")||die"打开失败\n";<br>print file "I love you!\n";<br>print file "I want to see you.\n";<br>close(file);<br>该段代码通过 unix 系统的 mail 程序,将 FILE 这个 FILEHANDLE 的数据内容寄给 $who 这个变量所指定的收信人。 <br><br><br>--------------------------------------------------------------------------------<br><br>指令:close<br>用法:close(filehandle)<br>说明:用 open 这个函数来打开一个 filehandle 之后,一定要用 close 批这个函数把所打开的 filehandle 关闭。<br>示例:<br>open(filehandle,"$filename");<br>close(filehandle);<br><br><br>--------------------------------------------------------------------------------<br><br>指令:pack<br>语法:pack("指定的格式",list)<br>说明:pack这个函数会将一个 list 变成所指定的二进制数据格式。在CGI程序分割解码过程中,会用到 pack 这个函数。<br>示例:<br>$string=pack("c",65); #这时 $string="a"; 将65这个ascii码转换成一个unsigned字符,其中c就是指定指转换成 unsigned 字符的意思。 <br><br><br>--------------------------------------------------------------------------------<br><br>指令:read<br>语法:read(filehandle,$string,length) 其中 length 是代表读入字符串的长度(bytes)。<br>说明:用 read 这个函数把 filehandle 中的数据依指定的字符串长度读入之后指派给 $string 这个变量。在cgi程序分割解码过程中,如果 FORM 的传送方式是设定为POST的话,就会将传送的数据设定为标准输入,所以会将数据内容指定给 STDIN 这个标准输入的 filehandle ,而CGI环境变量 $env{'content_length'} 就是代表使用者送出数据内容的长度,因此我们要用 read 这个函数来取得使用者送出的数据内容。<br>示例:<br>read(stdin,$buffer,$env{'content_length'}); # 就会将 stdin 这个标准输入 filehandle 中的数据依指定的字符串长度读入,再指派给 $buffer 这个变量。 <br><br><br>--------------------------------------------------------------------------------<br><br>指令:exit<br>语法:exit<br>说明:退出执行的程序。<br>示例:<br>print"i love cgi\n"; exit; # 表示显示完 "i love cgi" 以后,将退出这个程序。<br><br><br>--------------------------------------------------------------------------------<br><br><br> <br><br>7.5 文件操作<br> 大多数 Perl 程序都不是孤立的,它们与环境相互作用。很多的程序也需要通过文件操作实现数据的存贮和交换。文件句柄(file handle)是 Perl 程序中为程序和外部世界提供 I/O 连接的名称。建议在 Perl 程序中文件句柄全部使用大写字母,以示与变量等字符串的区别。特别地,可以将 STDIN/STDOUT/STDERR 也认为是 Perl 的文件句柄,分别代表 标准输入/标准输出/标准错误输出。<br><br><br><br>打开及关闭文件<br> Perl的文件操作与C语言极为相似。如:<br><br> open(FILENAME,"abc.txt");<br><br> 该调用为读文件打开,若为写文件而打开,需在文件名前加上大于号:<br><br> open(FILENAME,">abc.txt");<br><br> 若要追加至文件尾,可在文件名前加上两个大于号:<br><br> open(FILENAME,">>abc.txt");<br><br> 以上三种open()格式在成功时返回真,失败时返回假。但程序中通常没有提示,出错时往往会被人们忽略。 通常当需要给出出错提示时,可加入die()函数。例如:<br><br> open(OUTFILE,">/tmp/outfile")|| die "出错,不能建立/tmp/outfile\n";<br><br> 当 open 操作失败时,就会执行 die 给出出错提示。<br><br> 对文件句柄的操作完成后,可以用 close 操作符关闭文件。如:<br><br> close(OUTFILE);<br><br><br><br>文件测试<br> Perl的文件操作也可以先测试文件是否存在,是否可读写等,这样操作起来会更安全。如:<br><br> $x="abc.txt";<br> if(-e $x) { #abc.txt是否存在?<br> # 存在操作<br> } else {<br> printf "文件不存在。\n";<br> }<br><br> -e 操作符用于测试文件或目录是否存在。<br><br> 以下为所有文件测试操作符的清单:<br><br><br><br>文件测试 测试操作符提供的信息 <br>-r 文件或目录可读 <br>-w 文件或目录可写 <br>-x 文件或目录执行 <br>-o 文件或目录归用户所有 <br>-R 文件或目录对真正用户可读 <br>-W 文件或目录对真正用户可写 <br>-X 文件或目录对真正用户执行 <br>-O 文件或目录归真正用户所有 <br>-e 文件或目录存在 <br>-z 文件存在且大小为0 <br>-s 文件或目录存在且不为0(返回字节数) <br>-f 文件为普通文件 <br>-d 文件为目录 <br>-l 文件为符号链接 <br>-p 文件为命名管道(FIFO) <br>-S 文件为一个套口(socket) <br>-b 文件为块特殊文件 <br>-c 文件为字符特殊文件 <br>-t 打开tty控制台的文件句柄 <br>-u 文件或目录是设置用户ID号 <br>-g 文件或目录是设置用户组ID号 <br>-k 文件或目录的sticky位置位 <br>-T 文件是文本文件 <br>-B 文件是二进制文件 <br>-M 以天为单位的存在时间 <br><br>-A 以天为单位访问时间 <br>-C 以天为单位同代码更改时间 <br> <br><br>删除文件<br> Perl的 unlink() 操作符可实现删除文件。如:<br><br> unlink("abc.txt"); # 删除abc.txt<br><br><br><br>文件重命名<br> Perl的rename()操作符可实现文件重命名。如:<br><br> rename("abc","aka") || die "出错,不能更名"; <br><br> 此时将文件 abc 更名为 aka,成功返回真,否则给出出错提示。 <br><br><br><br>目录操作<br> Perl中处理目录非常类似于对文件的处理。<br><br> 打开目录句柄:<br><br> opendir(ETC,"/etc")||die "出错,不能打开目录";<br><br> 关闭目录句柄:<br><br> closedir(ETC);<br><br> 创建目录:<br><br> mkdir("aka",0777)||die "不能创建 aka 目录";<br><br> 0777 为文件权限描速数。<br><br> 删除目录:<br><br> rmdir("aka") || die "不能删除 aka 目录"。<br><br> <br><br>7.6 进程管理<br> 当你向系统 Shell 发送一个命令行时,Shell 创建一个进程来执行这个命令。这个新进程成为 Shell 的子进程,它的执行不依赖于 Shell 但又与 Shell 相互协调。 同样,Perl程序也能启动新进程。<br><br><br><br>使用system()和exec()<br> 生成新进程的最简单的方法就是用 system 操作符。如:<br><br> system("date");<br><br> 若要将输出送至now_day文件,则可以:<br><br> system("date>now_day") || die "不能建立now_day文件";<br><br><br><br>使用单引号<br> 产生进程的另一方法是将 Shell 命令置于两个单引号之间。如:<br><br> $nowday="现在时间:".'date'<br><br> $nowday 的值为“现在时间:”和date命令的结果的连接。即:"现在时间:Fri Feb 18 23:49:23 PDT 1998"<br><br><br><br>综合范例<br> 举一个综合例子,要求从date的输入中分析,周未时打印"周未了,轻松一下",否则打印"努力工作"。简洁的写法为:<br><br> if('date'=~/^S/){<br> printf "周未了,轻松一下\n";<br> } else {<br> printf "努力工作\n"<br> }<br><br> date 的输出格式第一个字节为星期,英语中恰好只有周未为 "S" 打头,因此使用了常规表达式判断第一个字符是否为S,即可达到要求。 <br> |
|