比如说: @array = ('ray','loca','simon','ray');
这里,我们想删除‘ray’这个元素。
列出几种方法:
1. 用grep函数。
函数名 grep
调用语法 @foundlist = grep (pattern,@searchlist);
解说 与同名的UNIX查找工具类似,grep函数在列表中抽取与指定模式匹配的元素,参数pattern为欲查找的模式,返回值是匹配元素的列表。
例子 @list = ("This","is","a","test");
@foundlist = grep(/^[tT]/,@list);
结果 @foundlist = ("This","test");
2. 用map函数
函数名 map
调用语法 @resultlist = map (expr,@list);
解说 此函数在Perl5中定义,可以把列表中的各个元素作为表达式expr的操作数进行运算,其本身不改变,结果作为返回值。在表达式expr中,系统变量$_代表各个元素。
例子 1、@list = (100,200,300);
@results = map ($_+1,@list);
2、@results = map (&mysub($_),@list);
结果 1、(101,201,301)
2、无
3. 用splice或者delete
函数名 splice
调用语法 @retval = splice (@array,slipelements,length,@newlist);
解说 拼接函数可以向列表(数组)中间插入元素、删除子列表或替换子列表。参数skipelements是拼接前跳过的元素数目,length是被替换的元素数,newlist是将要拼接进来的列表。当newlist的长度大于length时,后面的元素自动后移,反之则向前缩进。因此,当length=0 时,就相当于向列表中插入元素,而形如语句
splice (@array,-1,"Hello");
则向数组末尾添加元素。而当newlist为空时就相当于删除子列表,这时,如果length为空,就从第skipelements个元素后全部删除,而删除最后一个元素则为:splice (@array,-1);这种情况下,返回值为被删去的元素列表
两者都可以按照index直接删除array或者hash的元素。但是delete删除元素后,index后面的元素并不会
主动往前移动,该元素删除后,在array还留有一个undef的元素,显然删除得不够干净。
下面用个小程序说明具体操作:
程序:
程序运行结果为:
[ray@localhost perl]$ ./array_ops.pl
***show howto delete elements from array***
Old array is 'ray loca simon ray"Now array is "loca simon"Now array is " loca simon "Now array is "loca simon ray"Now array is "loca simon"
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。