(转)Perl的简单语法(与C语言语法…
来源:互联网 发布:mysql 修改端口号 编辑:程序博客网 时间:2024/06/05 17:01
下面将介绍一些 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。下面就来分别介绍他们。
指令:print
语法:print Filehandle LIST
说明:这个 Filehandle 可以看作在 I(INPUT)/O(OUTPUT) 之间的一个桥梁,可以利用FILEHANDLE 来做出数据读入写出的动作。STDIN是代表从哪里输入数据,例如从电脑的键盘输入;STDOUT是代表从哪里输出数据,例如从电脑的屏幕输出;STDERR是代表从哪里输出错误的数据,例如从电脑的屏幕输出。而在PERL语言中有三个标准FILEHANDLE:
1. STDIN(标准输入):是代表 STDIN 的 FILEHANDLE
2. STDOUT(标准输出):是代表 STDOUT 的 FILEHANDLE
3. STDERR(标准错误输出):是代表 STDERR 的 FILEHANDLE
如果要使用其他 FILEHANDLE 的时候,就要先用 OPEN 这个函数来打开一个 FILEHANDLE,我们可以用PRINT 这个函数将 LIST 中的数据输出给 FILEHANDLE。
语法: print LIST
说明: 如果省略 Filehandle 的话,就会把 Filehandle 默认为 STDOUT。也就是会将 LIST的数据内容显示在终端屏幕上。
语法: print
说明: 同时省略 Filehandle 和 LIST 的话,就会以 STDOUT 为 Filehandle,并会输出 $_这个系统内部变量的数据内容。如果 $_ 变量是一个空字符串的话,就会显示出一个空字符串。
指令: printf
语法: printf Filehandle LIST
说明: 在 Perl 语言中也提代 C 语言中 printf 的语法,用法和 C 语言中的用法一模一样。如果把Filehandle 省略的话,也一样会把 STDOUT 当成是默认的 Filehandle。
示例:
printf("chomod %d %s ","711""cgi"); 会将chmod 711cgi加上换行显示于屏幕上。
指令:chop 语法:chop($url)
说明:把最后一个字符删除。
示例:
$url="www.aka.org.cn/; chop($url);
这时$url="www.aka.org.cn" 还可以简写成 chop($url="www.aka.org.cn/");chop 函数一般用于去掉从键盘读入数据中的最后一个换行符。
指令:split
语法:split(/pattern/,$text,limit)其中/pattern/是文字处理的模式,而limit是代表要分割的个数,一般可以省略。
说明:用一个指定的文字处理模式来分割 $text 字符串。
示例:
$text="Michael,Gevin,Mike"; @name=split(/,/,$text); # 这时@name=("Michael","Gevin","Mike");
@name=split(/,/,$text,2); # 这时 @name=("Michael","Gevin");
在传送CGI应用程序数据的时候会先将数据编码,其中会将FORM中第个数据字段的数据内容用&这个符号隔开,所以在解码的时候就要以 "&"这个符号为分割的字符,将每个数据字段分割出。而数据字段的名称和这个数据字段的值是用=这个符号来隔开,如果想取得数据字段的名称和所对应的值的话,就用要 "=" 这个符号来分割数据字段,
指令:keys
语法:keys(%array)
说明:取出关联数组 %ARRAY 中全部的 key。
示例:
%NAME=(1,"mike",2,"michael"); @readkey=keys(%NAMES); # 这时@readkey=(1,2);
指令:values
语法:values(%array)
说明:取出关联数组 %ARRAY 中全部的 value。
示例:
%NAMES=(1,"mike",2,"michael"); @readval=values(%NAMES); #这时@readval=("mike","michael");
指令:reverse
语法:reverse(@array)
说明:将数组 @array 中的元素由后到前重新排列。
示例:
@back=("A","B","C","D","E"); @back=reverse(@back); # 这时@back=("E","D","C","B","A");
指令:sort
语法:sort(@array)
说明:将数组中的元素由小到大排序,如果要由大到小排序的话,要加上reverse这个函数。
示例:
@abc=("d","b","c","a"); @abc=sort(@abc); # 这时@abc=("a","b","c","d");
@abc=(reverse sort@abc); # 这时@abc=("d","c","b","a"); 这个语法也可以写成@abc=(reverse sort(@abc));
@number=(5,2,10); @number=sort(@number);
# 上面示例用sort函数来排序数值的时,会出差错,因此要用下面到下面这一句。
@number=(sort{$a<=>$b}@number);# 这时 @number=(2,5,10);
指令:length
语法:length($string)
说明:求出字符串$string的字节(bytes)值。
示例:
$string="Perl5"; $size=length($string); # 这时 $size=5;
指令:substr
语法:substr($string,offset,length)offset代表起始字符的位置,length代表引用的字符串长度,如果省略length则代表从起始值到字符串的最后一个字符长度。而offset如果是负值的话,就会从字符串右边开始指定字符。
示例:
$s=substr("perl5",2,2); # 这时 $s="rl";
$s=substr("perl5",2); # 这时 $s="rl5";
$s=substr("perl5",-2,2); # 这时 $s="er";
指令:index
语法:index($string,$substring,position)$substring是要寻找的字符;position代表从哪一个位置开始寻找,假如省略position就从头开始找起。
说明:返回所要找寻的字符在一字符串$string中的位置,如果在字符串中找不到字符的话,则会返回-1这个 值。
示例:
$s=index("perl5","p"); # 这时 $s=0
$s=index("perl5","l",2); # 这时 $s=3
$s=index("perl5","perl"); # 这时 $s=-1
指令:push
语法:push(@array,$string)
说明:在数组@array的最后附加新的元素 ($string)到数组@array中。
示例:
@array=("one","two"); push(@array,"three"); # 这时@array=("one","two","three")
指令:pop
语法:pop(@array)
说明:将数组(@array)的最后一个元素删除,并将删除的元素返回。
示例:
@array=("one","two"); $rm=pop(@array); # 这时@array=("one");而$rm="two";
指令:unshift
语法:unshift(@array,$string)
说明:在数组@array的第一个元素前附加新的元素$string到数组@array中。
示例:
@array=("one","two"); unshift(@array,"three"); # 这时@array=("three","one","two")
指令:shift
语法:shift(@array)
说明:将数组@array的第一个元素删除,并将删除的元素返回。
示例:
@array=("one","two"); @rm=shift(@array); # 这时@array=("two");而$rm="one";
指令:join
语法:join($string,@array)
说明:在一数组@array的元素之间加上一指定的字符$string,并将结果返回。
示例:
@array=("one","two","three");
$total=join(":",@array); 这时 $total="one:two:three";
指令:grep
语法:grep(/pattern/,@array)
说明:将合文字处理模式(regular expression)的数组元素找出来。
示例:
@array=("one","on","in");
$count=grep(/on/,@array); # 这时 $count=2
@result=grep(/on/,@array); # 这时 @result=("one","on");
指令:hex
语法:hex($string)
说明:将十六进制的数值转成十进制。
示例:
$decimal=hex("ff"); 这时 $decimal=255;
指令:rand
语法:rand($interger)
说明:常和函数srand搭配来取得一随机数,如果没有先宣告stand函数的话,则取出的常数值是一个固定值。这个语法会返回一个介于0 和$interger之间的数值,如果$interger省略的话,则会返回一个介于 0 和 1 的数值。
示例:
srand; # 要先调用一次srand函数,才能产生随机数的效果
$int=rand(10); # $int的值会大于 0 而且小于 10 ,如果希望产生的乱数是整数的话,就要再加上int这个函数,如下
$int=int(rand(10)); # $int的值是一个整数,且值在 0 和 9 之间
指令:localtime
语法:localtime(time)
说明:可返回九个有关时间的元素,在写CGI应用程序的时候常会用到系统的时间,所以在此会详细介绍这个函数的用法。
示例:
($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst)=localtime(time);
其中: $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 应用程序中拿来应用了。
此外,也可以用下面 这一行指令在 UNIX系统下取得系统的时间。为了避免错误发生,最好用绝对路径的方法来取得系统时间,如果绝对路径不清楚的话可以用 "which data"这个指令来得知。$data='/usr/bin/data'; 而在 Perl 5 版本中,也可以用下面这一行指令来取得系统时间。$data=localtime(time);
指令:die
语法:die LIST
说明:会把LIST字符串显示出来,并退出程序。常常和 $! 这个代表错误信息变量一起使用。
示例:
open(FILE,"$filename")||die "不能打开文件$! ; #如果打开文件失败的话,就会显示出错误的信息,之后再退出程序。
指令:open
语法1:open(filehandle,"$filename") 其中 $filename 是一个指定打开的文件名。
说明:这是一个很常用的函数,可用于文件的打开(read only)。
示例:
$filename="usr/abc.txt";
open(FILE,"$filename")||die"不能打开文件$filename
; #将<file>数据指定给纯变量$line(一行一行地)
while($line=)
{
print"$line";
}
close(file); 就会把abc.txt这个文件的内容显示出来。
语法2:open(filehandle,"<$filename")
说明:这个语法也可以打开一个存在的文件(read only)。
示例:
$filesname="usr/abc.txt";
open(file,"<$filename")||die"不能打开文件$filename
";
@array=<file> # 将 全部的数据内容都指定给数组@array
close(file);
print "@array"; # 也会把abc.TXT这个文件的内容显示出来。
语法3:open(filehandle,">$filename")
说明:建立一个新的文件(write only);如果已经存在这个文件了,就会把旧文件名覆盖掉。并可用printfilehandle的方式将数据存入打开的文件中。
示例:
$filename="/usr/abc.txt";
open(file,">$filename")||die"不能打开文件$filename
;
print file "this is a new line1
; #
是换行字符
print file "this is a new line2
;
close(file); # 会将数据存在一个新文件中。
语法4:open(filehandle,">>$filename")
说明:数据用附加的方式定入一文件(write only),如果指定的文件名不存在的话就会建立一个新的文件。
示例:
$filename="/path/abc.txt";
open(file,">>$filename")||die"不能打开文件$filename
";
print file "this is a new line1
";
print file "this is a new line2
";
close(file); # 会打数据附加(append)到一个文件(abc.txt)中。
语法5:open(filehandle,"|unix command")
说明:就会把在filehandle的数据输入给unix的指令来作处理。
示例:
$mailprog="/usr/ucb/mail"; # unix系统上的寄信程序(一定要加绝对路径)
$who="mqingyi@126.com";
$open(file,"|$mailprog$who")||die"打开失败
";
print file "I love you!
";
print file "I want to see you.
";
close(file);
该段代码通过 unix 系统的 mail 程序,将 FILE 这个 FILEHANDLE 的数据内容寄给 $who这个变量所指定的收信人。
指令:close
用法:close(filehandle)
说明:用 open 这个函数来打开一个 filehandle 之后,一定要用 close 批这个函数把所打开的filehandle 关闭。
示例:
open(filehandle,"$filename");
close(filehandle);
指令:pack
语法:pack("指定的格式",list)
说明:pack这个函数会将一个 list 变成所指定的二进制数据格式。在CGI程序分割解码过程中,会用到 pack这个函数。
示例:
$string=pack("c",65); #这时 $string="a";将65这个ascii码转换成一个unsigned字符,其中c就是指定指转换成 unsigned 字符的意思。
指令:read
语法:read(filehandle,$string,length) 其中 length是代表读入字符串的长度(bytes)。
说明:用 read 这个函数把 filehandle 中的数据依指定的字符串长度读入之后指派给 $string这个变量。在cgi程序分割解码过程中,如果 FORM的传送方式是设定为POST的话,就会将传送的数据设定为标准输入,所以会将数据内容指定给 STDIN 这个标准输入的filehandle ,而CGI环境变量 $env{'content_length'} 就是代表使用者送出数据内容的长度,因此我们要用read 这个函数来取得使用者送出的数据内容。
示例:
read(stdin,$buffer,$env{'content_length'}); # 就会将 stdin 这个标准输入filehandle 中的数据依指定的字符串长度读入,再指派给 $buffer 这个变量。
指令:exit
语法:exit
说明:退出执行的程序。
示例:
print"i love cgi "; exit; # 表示显示完 "i love cgi" 以后,将退出这个程序。
5 文件操作
大多数 Perl程序都不是孤立的,它们与环境相互作用。很多的程序也需要通过文件操作实现数据的存贮和交换。文件句柄(file handle)是 Perl程序中为程序和外部世界提供 I/O 连接的名称。建议在 Perl程序中文件句柄全部使用大写字母,以示与变量等字符串的区别。特别地,可以将 STDIN/STDOUT/STDERR 也认为是 Perl的文件句柄,分别代表 标准输入/标准输出/标准错误输出。
打开及关闭文件
Perl的文件操作与C语言极为相似。如:
open(FILENAME,"abc.txt");
该调用为读文件打开,若为写文件而打开,需在文件名前加上大于号:
open(FILENAME,">abc.txt");
若要追加至文件尾,可在文件名前加上两个大于号:
open(FILENAME,">>abc.txt");
以上三种open()格式在成功时返回真,失败时返回假。但程序中通常没有提示,出错时往往会被人们忽略。通常当需要给出出错提示时,可加入die()函数。例如:
open(OUTFILE,">/tmp/outfile")|| die"出错,不能建立/tmp/outfile ";
当 open 操作失败时,就会执行 die 给出出错提示。
对文件句柄的操作完成后,可以用 close 操作符关闭文件。如:
close(OUTFILE);
文件测试
Perl的文件操作也可以先测试文件是否存在,是否可读写等,这样操作起来会更安全。如:
$x="abc.txt";
if(-e $x) { #abc.txt是否存在?
# 存在操作
} else {
printf "文件不存在。
";
}
-e 操作符用于测试文件或目录是否存在。
以下为所有文件测试操作符的清单:
文件测试测试操作符提供的信息-r文件或目录可读-w文件或目录可写-x文件或目录执行-o文件或目录归用户所有-R文件或目录对真正用户可读-W文件或目录对真正用户可写-X文件或目录对真正用户执行-O文件或目录归真正用户所有-e文件或目录存在-z文件存在且大小为0-s文件或目录存在且不为0(返回字节数)-f文件为普通文件-d文件为目录-l文件为符号链接-p文件为命名管道(FIFO)-S文件为一个套口(socket)-b文件为块特殊文件-c文件为字符特殊文件-t打开tty控制台的文件句柄-u文件或目录是设置用户ID号-g文件或目录是设置用户组ID号-k文件或目录的sticky位置位-T文件是文本文件-B文件是二进制文件-M以天为单位的存在时间-A以天为单位访问时间-C以天为单位同代码更改时间删除文件
Perl的 unlink() 操作符可实现删除文件。如:
unlink("abc.txt"); # 删除abc.txt
文件重命名
Perl的rename()操作符可实现文件重命名。如:
rename("abc","aka") || die "出错,不能更名";
此时将文件 abc 更名为 aka,成功返回真,否则给出出错提示。
目录操作
Perl中处理目录非常类似于对文件的处理。
打开目录句柄:
opendir(ETC,"/etc")||die "出错,不能打开目录";
关闭目录句柄:
closedir(ETC);
创建目录:
mkdir("aka",0777)||die "不能创建 aka 目录";
0777 为文件权限描速数。
删除目录:
rmdir("aka") || die "不能删除 aka 目录"。
7.6 进程管理
当你向系统 Shell 发送一个命令行时,Shell 创建一个进程来执行这个命令。这个新进程成为 Shell的子进程,它的执行不依赖于 Shell 但又与 Shell 相互协调。 同样,Perl程序也能启动新进程。
使用system()和exec()
生成新进程的最简单的方法就是用 system 操作符。如:
system("date");
若要将输出送至now_day文件,则可以:
system("date>now_day") || die"不能建立now_day文件";
使用单引号
产生进程的另一方法是将 Shell 命令置于两个单引号之间。如:
$nowday="现在时间:".'date'
$nowday 的值为“现在时间:”和date命令的结果的连接。即:"现在时间:Fri Feb 18 23:49:23PDT 1998"
综合范例
举一个综合例子,要求从date的输入中分析,周未时打印"周未了,轻松一下",否则打印"努力工作"。简洁的写法为:
if('date'=~/^S/){
printf "周未了,轻松一下
";
} else {
printf "努力工作
"
}
date 的输出格式第一个字节为星期,英语中恰好只有周未为 "S"打头,因此使用了常规表达式判断第一个字符是否为S,即可达到要求。
- (转)Perl的简单语法(与C语言语法…
- (转)Perl的简单语法(与C语言语法…
- [zt] Perl的简单语法(与C语言语法的异同)
- Perl 的简单语法
- Perl的简单语法
- 简单的C语言语法-scanf
- Python语法与类C语言语法的差别
- perl 简单语法积累
- 一个简单的C语言词法分析与语法分析器【原】
- c语言实现一个简单的语法分析器
- [转]C语言语法小结
- perl基本语言语法(与java,c#不同的地方积累)
- 【C语言】语法--++i与i++的区别
- C语言语法上与C++的不同之处-作为笔记
- 【C语言】语法-typedef用法及与define的区别
- object-c 与 java,c#等语言的 语法区别
- 【Java语法与C语言的区别】一
- perl的基本语法(转)
- 内存对齐全攻略--二、涉及位域的内…
- 深度学习数据集准备:使用photoshop 批处理图像数据
- (转)Perl的简单语法(与C语言语法…
- linux信号量
- ubable to locate package java
- (转)Perl的简单语法(与C语言语法…
- (转)MTK文件操作常用函数
- MTK_面试的几个主要问题
- (转)MTk屏幕切换效果的制作
- MTK的铃声修改与替换
- 转载 MTK存储系统相关
- (转)同步/异步与阻塞/非阻塞的区别
- 关于人生规划选择的一个哲理故事
- java集合框架的讲解