PERL 常用函数集锦

相关主题
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
指令: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
指令: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);
说明:将数组中的元素由小到大排序,如果要由大到小排序的话,要加上 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")
指令: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";
而众所周知,Perl 之所以被很多人所采用的原因,很大一部分在于它简洁的语法和对字符以及数组的超强控制功能,可以说它包含了“最大适度 的灵活性和稳定性”,现在这里,石头整理并总结了网上的一些资料,以及自己总结出这篇文章,希望对所有的 Perl 爱好者有一定的帮助和参 阅价值
指令: printf 语法: printf Filehandle LIST 说明: 在 perl 语言中也提代 C 语言中 printf 的语法,用法和 C 语言中的用法一模一样.如果把 Filehandle 省略的话 ,也一样会把 STDOUT 当成是 内定的 Filehandle.在为大家介绍 printf 函数之前,先让我们来看看 printf 函数中变换符号的字符.
指令:join 语法:join($string,@array) 说明:与 split 恰恰相反:在一数组@array 的元素之间加上一指定的字符$string,并将结果返回。 示例: @array=("one","two","three"); $total=join(":",@array); 这时$total="one:two:three";
指令:pop 语法:pop(@array) 说明:将数组(@array)的最后一个元素删除,并将删除的元素返回。 示例:@array=("one","two"); $rm=pop(@array); #这时@array=("one");而$rm="two";
指令:unshift 语法:unshift(@array,$string) 说明:在数组@array 的第一个元素前附加新
1 Perl 常用函数集锦
最近在研究 Perl ,发现 Perl 的确如 Larry Wall 所说“是一门极其有趣的语言”,然而,Perl 的价值远不止于此 —— “Perl 对真实生 活的反映--他的人性特征--是内建于这门语言的深厚的哲学结构。”Perl 是第一个后现代的计算机语言,Wall 说,“一个人造自然语言,模拟了 程序员是如何思考的”。可以说,Perl 沿着一门真实语言的道路发展,吸收了长期以来其他语言的优点 —— 有一些 Unix,一些 c++,一些 BASIC, 一点这个,一点那个 ... 如果其他任何人有一些新鲜、有用的东西,Perl 会包含他。当 Wall 调用这些“后现代主义”的概念,他是指 Perl 的折 衷、包容的方式 —— 在每一个隐蔽处和裂缝中都可以找到的一点点真理的能力,同时不用使它自己被任何大的真理所包围。
指令:map 语法:map(&function,@array) 或 map {&function} @array 说明:功能强大的数组操作函数。将一个输入数组做相应转换然后传给指定函数的输出数组。 示例 1: @intergers=(1,2,3); @twiceAsBig=map($_*2,@intergers);#这时@match=(2,4,6); 示例 2:(拼写错误的词组)
指令: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";
指令:reverse 语法:reverse(@array) 说明:将数组@array 中的元素由后到前重新排列。 示例:@back=("A","B","C","D","E"); @back=reverse(@back); #这时@back=("E","D","C","B","A");
指令:sort 语法:sort(@array)
作者: 221.217.159.* 2010-1-1 11:26 -------------------------------------------------------------------------------2 Perl 常用函数集锦 的元素$string 到数组@array 中。 示例: @array=("one","two"); unshift(@array,"three"); #这时@array=("three","one","two")
符号 其作用 %c 字符 %s 字符串 %d 整数 %f 浮整数
%h 十六进制码 %o 八进制码 示例:printf("chomod%d%s ","755","cgi"); 会将 chmod 71ห้องสมุดไป่ตู้ cgi 加上换行显示于屏幕上。
指令:length 语法:length($string) 说明:求出字符串$string 的字节(bytes)值。 示例:$string="Perl5"; $size=length($string); #这时$size=5;
指令: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");
指令: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");
指令:chop 语法:chop($url) 说明:把最后一个字符删除。(也可以用类似结构 chop(@array)来删除数组最后一个元素) 示例:$url="http://project.livedoor.cn/~huangjs/"; chop($url); 这时$url=http://project.livedoor.cn/~huangjs 而这两行也可以写成 chop($url="http://project.livedoor.cn/~huangjs/");
相关文档
最新文档