7個(gè)perl數(shù)組高級(jí)操作技巧分享
1、去除一個(gè)數(shù)組中的重復(fù)元素:
使用grep函數(shù)代碼片段:
代碼:
my @array = ( 'a', 'b', 'c', 'a', 'd', 1, 2, 5, 1, 5 );
my %count;
my @uniq_times = grep { ++$count{ $_ } < 2; } @array;
使用轉(zhuǎn)換hash代碼片段:
代碼:
my @array = ( 'a', 'b', 'c', 'a', 'd', 1, 2, 5, 1, 5 );
my %saw;
@saw{ @array } = ( );
my @uniq_array = sort keys %saw;
2、合并兩個(gè)array:
push @array1, @array2;
3、快速查找最大值,不知道的程序猿們,這樣搞:
my @nums = 0 .. 1000;
my $max = $nums[0];
foreach (@nums) {
$max = $_ if $_ > $max;
}
知道的這樣搞:
use List::Util qw(max);
my $max_num = max( 0 .. 1000 );
知道的他們還這樣搞:
use List::Util qw(maxstr);
my $max_str = maxstr ( qw( Fido Spot Rover ) );
字符串比較玩弄于掌中。還有sum:
use List::Util qw(sum);
my $sum = sum ( 1 .. 1000 );
4、列表歸并
數(shù)字求和,也可以用List::Util中的reduce:
use List::Util qw(reduce);
my $sum = reduce { $a + $b } 1 .. 1000;
與sort類似,reduce也是用code block作為參數(shù),不過運(yùn)行機(jī)制稍微不同。每次迭代,先從參數(shù)列表取出前面兩個(gè)元素,分別設(shè)置為別名$a和$b,這樣參數(shù)列表的長度就會(huì)縮短為兩個(gè)元素。然后reduce把語句塊返回的計(jì)算結(jié)果再壓回到參數(shù)列表的頭部。如此往復(fù),直到最后列表里只剩下一個(gè)元素,也就是迭代的計(jì)算結(jié)果$sum。
好了,可以這樣了:
my $product = reduce { $a * $b } 1 .. 1000;
5、判斷是否有元素匹配
純粹用Perl實(shí)現(xiàn),找到列表中第一個(gè)符合某條件的元素,比找出所有符合條件的要麻煩一些。下面的例子,判斷是否有大于1000的元素:
my $found_a_match = grep { $_ > 1000 } @list;
注意:如果@list有一億個(gè)元素,而要找的就是1001?grep仍然還會(huì)循環(huán)一億次,當(dāng)然你可以向下面自己控制下:
my $found_a_match = 0;
foreach my $elem (@list) {
$found_a_match = $elem if $elem > 1000;
last if $found_a_match;
}
還是那句話,不簡單~~~List::Util有現(xiàn)成的東西:
use List::Util qw(first);
my $found_a_match = fist { $_ > 1000 } @list;
在List::MoreUtils模塊中,也提供很多的實(shí)用函數(shù):
my $found_a_match = any { $_ > 1000 } @list;
my $all_greater = all { $_ > 1000 } @list;
my $none_greater = none { $_ > 1000 } @list;
my $all_greater = notall { $_ % 2 } @list;
6、一次遍歷多個(gè)列表
一般我們同時(shí)遍歷多個(gè)業(yè)務(wù)相關(guān)的列表時(shí),往往用數(shù)組下標(biāo)遍歷:
my @a = ( ... );
my @b = ( ... );
my @c;
foreach my $i ( 0 .. $#list ) {
my ( $a, $b ) = ( $a[$i], $b[$i] );
push @c, $a + $b;
}
看下面這個(gè),你的感覺是?
use List::MoreUtils qw(pairwise);
my @c = pairwise { $a + $b } @a, @b;
pairwise只適合兩個(gè)列表的同步計(jì)算,三個(gè)后用each_array:
use List::MoreUtils qw(each_array);
my $ea = each_array( @a, @b, @c );
my @d;
while ( my ( $a, $b, $c ) = $ea->() ) {
push @d, $a+$b+$c;
}
雖然還是有點(diǎn)煩,不過也還好了。
7、數(shù)組合并
合并多個(gè)數(shù)組的操作當(dāng)然你可以自己寫,但終究不如MoreUtils的mesh方便:
use List::MoreUtils qw(mesh);
my @odds = qw/ 1 3 5 7 9/;
my @evens= qw/ 2 4 6 8 0/;
my @nums = mesh @odds, @evens; # print: 1 2 3 4 ...
- perl批量查詢ip歸屬地的方法代碼
- perl中my和our的區(qū)別分析
- 解析posix與perl標(biāo)準(zhǔn)的正則表達(dá)式區(qū)別
- Perl中的正則表達(dá)式介紹
- 為Java程序員準(zhǔn)備的10分鐘Perl教程
- Perl內(nèi)置特殊變量總結(jié)
- Perl Sort函數(shù)用法總結(jié)和使用實(shí)例
- Perl調(diào)用shell命令方法小結(jié)
- perl 文件測試操作符匯總
- Perl使用nginx FastCGI環(huán)境做WEB開發(fā)實(shí)例
- perl查找進(jìn)程PID的例子
- Perl一句話命令行編程中常用參數(shù)總結(jié)
- cpanm安裝及Perl模塊安裝教程
- Windows和Linux系統(tǒng)下perl連接SQL Server數(shù)據(jù)庫的方法
- Perl函數(shù)(子程序)學(xué)習(xí)筆記
- Perl Substr()函數(shù)及函數(shù)的應(yīng)用
相關(guān)文章
perl子程序的運(yùn)用及子程序中變量私有(my)聲明的重要性
perl中的my可以來定義私有變量,可以在很多情況下防止錯(cuò)誤的發(fā)生2013-02-02Perl使用File::Basename獲取文件擴(kuò)展名的代碼
本文為大家介紹的這個(gè)例子,實(shí)現(xiàn)了獲取/home/topgkw中所有文件后綴,其中目錄返回空值2013-02-02Perl localtime時(shí)間函數(shù)的應(yīng)用介紹
Perl時(shí)間函數(shù)localtime的使用介紹,這里簡單的介紹下,更多請(qǐng)查看官方介紹2013-02-02Perl中的控制結(jié)構(gòu)學(xué)習(xí)筆記
這篇文章主要介紹了Perl中的控制結(jié)構(gòu)學(xué)習(xí)筆記,本文講解了條件語句if、條件語句unless、循環(huán)語句while、循環(huán)語句until、for循環(huán)、foreach語句、循環(huán)控制等內(nèi)容,需要的朋友可以參考下2014-11-11Perl圖形化包管理工具PPM學(xué)習(xí)使用筆記
這篇文章主要介紹了Perl圖形化包管理工具PPM學(xué)習(xí)使用筆記,本文詳細(xì)講解了什么是PPM、PPM界面的功能按鈕說明、PPM如何安裝卸載包等內(nèi)容,需要的朋友可以參考下2015-06-06