1 Perl 常用函数集锦
最近在研究 Perl ,发现 Perl 的确如 Larry Wall 所说“是一门极其有趣的语言”,然而,Perl 的价值远不止于此——“Perl对真实生活的反映--他的人性特征--是内建于这门语言的深厚的哲学结构。”Perl是第一个后现代的计算机语言,Wall说,“一个人造自然语言,模拟了程序员是如何思考的”。可以说,Perl沿着一门真实语言的道路发展,吸收了长期以来其他语言的优点——有一些Unix,一些c++,一些BASIC,一点这个,一点那个 ... 如果其他任何人有一些新鲜、有用的东西,Perl会包含他。当Wall调用这些“后现代主义”的概念,他是指Perl的折衷、包容的方式——在每一个隐蔽处和裂缝中都可以找到的一点点真理的能力,同时不用使它自己被任何大的真理所包围。
而众所周知,Perl 之所以被很多人所采用的原因,很大一部分在于它简洁的语法和对字符以及数组的超强控制功能,可以说它包含了“最大适度的灵活性和稳定性”,现在这里,石头整理并总结了网上的一些资料,以及自己总结出这篇文章,希望对所有的 Perl 爱好者有一定的帮助和参阅价值
指令: printf
语法: printf Filehandle LIST
说明:在perl语言中也提代C语言中printf的语法,用法和C语言中的用法一模一样.如果把Filehandle省略的话 ,也一样会把STDOUT当成是内定的Filehandle.在为大家介绍printf函数之前,先让我们来看看printf函数中变换符号的字符.
符号其作用
%c 字符
%s 字符串
%d 整数
%f 浮整数
%h 十六进制码
%o 八进制码
示例:printf("chomod%d%s ","755","cgi"); 会将chmod 711 cgi加上换行显示于屏幕上。
指令:length
语法:length($string)
说明:求出字符串$string的字节(bytes)值。
示例:$string="Perl5"; $size=length($string); #这时$size=5;
指令:chop
语法:chop($url)
说明:把最后一个字符删除。(也可以用类似结构chop(@array)来删除数组最后一个元素)
示例:$url="https://www.doczj.com/doc/df6094422.html,/~huangjs/";
chop($url); 这时$url=https://www.doczj.com/doc/df6094422.html,/~huangjs 而这两行也可以写成chop($url="https://www.doczj.com/doc/df6094422.html,/~huangjs/");
指令: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";
指令:split
语法:split(/pattern/,$text,limit) 其中/pattern/是文字处理的模式,而limit是代表要分割的个数,一般可以省略。
说明:用一个指定的文字处理模式来分割$text字符串。
示例:
$text="Michael,Gevin,Mike"; @name=split(/,/,$text); #这时@name=("Michael","Gevin","Mike");
($a,$b,$c)=split(/,/,$text); #这时$a="Michael";$b="Gevin";$c="Mike";
@name=split(/,/,$string,2); #这时@name=("Michael","Gevin");
在传送CGI应用程序数据的时候会先将数据编码,其中会将FORM中第个数据字段的数据内容用&这个符号隔开,所以在解码的时候就要以&这个符号为分割的字符,将每个数据字段分割出。例如: $text="Mike=A&Michael=B";
@name=split(/&/,$text); #这时@name=("Mike=A","Michael=B"); 而数据字段的名称和这个数据字段的值是用=这个符号来隔开,如果想取得数据字段的名称和所对应的值的话,就用要=这个符号来分割数据字段,例如: $name=""Mike=Michael"";
($name1,$name2)=split(/=/,$list); #这时$name1="Mike";$name2="Michael";
指令:join
语法:join($string,@array)
说明:与split恰恰相反:在一数组@array的元素之间加上一指定的字符$string,并将结果返回。
示例:
@array=("one","two","three");
$total=join(":",@array); 这时$total="one:two:three";
指令: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
指令: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);
指令:scalar
语法:scalar(@array)
说明:获得数组@array的长度。
示例:@abc=("d","b","c","a"); $num=scalar(@abc); #这时$num=4;
指令: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的第一个元素前附加新
作者: 221.217.159.* 2010-1-1 11:26
--------------------------------------------------------------------------------
2 Perl 常用函数集锦
的元素$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";
指令:splice
语法:
1. splice(@array,$position,$length,@list);
2. splice(@array,$position,$length);
3. splice(@array,$position);
说明:强大的复杂数组处理函数:用法1是先取走了数组$position起$length长度的元素,并在其原先位置插入@list;用法2是删除数组$position 起$length长度的元素;用法3是删除$position后面的所有元素。
示例:
@array=("e1","e2","e3","e4");
@return=splice(@array,1,2,("e11","e22","e33")); 这时@array=("e1","e11","e22","e33","e4");
指令:undef
语法:undef(@array)
说明:将数组@array变成一个空白数组。
示例:@array=("one","two"); undef(@array); #这时@array就变为一个空数组了;
指令:grep
语法:grep(EXPERSION,@array) 或 grep {FUNCTION} @array
说明:功能强大的模式匹配函数。由于篇幅这里仅介绍将合文字处理模式(regular expression)的数组元素找出来的方法,以及在数组处理方面的部分功能。
示例 1:
@intergers=(0,1,2,3,4,5,6,7,8,9);
@matches=grep($_>5,@intergers);#这时@match=(6,7,8,9);
示例 2:(去掉重复项)
@original=(1,1,2,2,3,3,4,4);
@duplicate=grep {$marked{$_}++;$marked{$_}==1;} @original;#这时@duplicate=(1,2,3,4);
指令:map
语法:map(&function,@array) 或 map {&function} @array
说明:功能强大的数组操作函数。将一个输入数组做相应转换然后传给指定函数的输出数组。
示例 1:
@intergers=(1,2,3);
@twiceAsBig=map($_*2,@intergers);#这时@match=(2,4,6);
示例 2:(拼写错误的词组)
my %dictionary = map { $_, 1 } qw(cat dog man woman hat glove); my @words = qw(dog kat wimen hat man gloove);
foreach my $word (@words) {
if (not $dictionary{$word}) {
print "Possible misspelled word: $word ";
}
}
输出结果:
Possible misspelled word: kat
Possible misspelled word: wimen
Possible misspelled word: gloove
指令: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,365] $isdst只是一个flag 知道这些变量之后,就可以在CGI应用程序中拿来应用了。此外,也可以用下面这一行指令在UNIX系统下取得系统的时间。为了避免错误发生,最好用绝对路径的方法来取得系统时间,如果绝对路径不清楚的话可以用"which data"这个指令来得知。最后要提字符的话,就不能正确执行系统的程序了。 $data='/usr/bin/data'; 而在perl5版本中,也可以用下面这一行指令来取得系统时间。 $data=localtime(time);
指令:die
语法:die LIST
说明:会把LIST字符串显示出来,并退出程序。常常和$!这个代表错误信息变量一起使用。
示例:open(FILE,"$filename")||die "不能打开文件$! ; 如果打开文件失败的话,就会显示出错误的信息,之后再退出程序。
从群体上看,中专毕业生的劣势是阅历较少、知识层次相对不高;优势是学校专业设置大多贴近市场实际、贴近一线需要,且中专毕业生年青、肯吃苦、可塑性强。从个体来说,每位毕业生的优势与长项又各不相同,如有相当一部分毕业生动手操作能力较好;有些学生非常上进,上学期间还同时参加了职业资格考试或自学考试。所以,在实事求是,不弄虚作假的前提下,要特别注意扬长避短,从而在竞争中取得优势,打动聘任者。没有重点和章法的写作易使文章显得头绪不清、条理紊乱。
非常热爱市场销售工作,有着十分饱满的创业激情。在××××两年从事现
磨现煮的咖啡市场销售工作中积累了大量的实践经验和客户资源。与省内主要的二百多家咖啡店铺经销商建立了十分密切的联系,并在行业中拥有广泛的业务关系。在去年某省的咖啡博览会上为公司首次签定了海外的定单。能团结自己的同事一起取得优异的销售业绩。
合理分配自我介绍的时间前文说过,自我介绍一般也就持续1—3分钟,所以应聘者得合理分配时间。常规安排是:第一段用于表述个人基本情况,中段重点谈自己的工作经历或社会实践经验,最后展望下自己的职位理想。但如果自我介绍被要求在1分钟完成,应聘者就要有所侧重,突出最有料的一点。在实践中,有些应聘者试图在短短的时间内吐露自己的全部经历,而有些应聘者则是三言两语就完成了自我介绍,这些都是不明智的做法。
突出和应聘职位相关的信息自我介绍的内容不宜太多的停留在诸如姓名、教育经历等部分上,因为面试官可以在应聘者的简历上一目了然地看到这些内容。应聘者应该在自我介绍时选择一至两项跟自己所应聘的职位相关的经历和成绩作简述,以证明自己确实有能力胜任所应聘的工作职位。一个让人更有机会在面试中出彩的方法是在做一段自我介绍后适当停顿。比如在“我曾在大学期间组织过有2000人参与的大型校园活动”
之后的停顿可能会引导面试官去问“那是什么样的活动呢?”,这样做的目的是为面试的深入打下基础。