佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > 7個perl數(shù)組高級操作技巧分享

7個perl數(shù)組高級操作技巧分享

熱門標簽:電話運營中心 企業(yè)做大做強 Win7旗艦版 語音系統(tǒng) 客戶服務(wù) 硅谷的囚徒呼叫中心 呼叫中心市場需求 百度AI接口

1、去除一個數(shù)組中的重復元素:

使用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、合并兩個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ù),不過運行機制稍微不同。每次迭代,先從參數(shù)列表取出前面兩個元素,分別設(shè)置為別名$a和$b,這樣參數(shù)列表的長度就會縮短為兩個元素。然后reduce把語句塊返回的計算結(jié)果再壓回到參數(shù)列表的頭部。如此往復,直到最后列表里只剩下一個元素,也就是迭代的計算結(jié)果$sum。

好了,可以這樣了:

復制代碼 代碼如下:

my $product = reduce { $a * $b } 1 .. 1000;

5、判斷是否有元素匹配

純粹用Perl實現(xiàn),找到列表中第一個符合某條件的元素,比找出所有符合條件的要麻煩一些。下面的例子,判斷是否有大于1000的元素:

復制代碼 代碼如下:

my $found_a_match = grep { $_ > 1000 } @list;

注意:如果@list有一億個元素,而要找的就是1001?grep仍然還會循環(huán)一億次,當然你可以向下面自己控制下:
復制代碼 代碼如下:

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ù):
復制代碼 代碼如下:

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、一次遍歷多個列表

一般我們同時遍歷多個業(yè)務(wù)相關(guān)的列表時,往往用數(shù)組下標遍歷:

復制代碼 代碼如下:

my @a = ( ... );
my @b = ( ... );
my @c;

foreach my $i ( 0 .. $#list ) {
my ( $a, $b ) = ( $a[$i], $b[$i] );
push @c, $a + $b;
}


看下面這個,你的感覺是?
復制代碼 代碼如下:

use List::MoreUtils qw(pairwise);
my @c = pairwise { $a + $b } @a, @b;

pairwise只適合兩個列表的同步計算,三個后用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;
}


雖然還是有點煩,不過也還好了。

7、數(shù)組合并

合并多個數(shù)組的操作當然你可以自己寫,但終究不如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標準的正則表達式區(qū)別
  • Perl中的正則表達式介紹
  • 為Java程序員準備的10分鐘Perl教程
  • Perl內(nèi)置特殊變量總結(jié)
  • Perl Sort函數(shù)用法總結(jié)和使用實例
  • Perl調(diào)用shell命令方法小結(jié)
  • perl 文件測試操作符匯總
  • Perl使用nginx FastCGI環(huán)境做WEB開發(fā)實例
  • perl查找進程PID的例子
  • Perl一句話命令行編程中常用參數(shù)總結(jié)
  • cpanm安裝及Perl模塊安裝教程
  • Windows和Linux系統(tǒng)下perl連接SQL Server數(shù)據(jù)庫的方法
  • Perl函數(shù)(子程序)學習筆記
  • Perl Substr()函數(shù)及函數(shù)的應(yīng)用

標簽:長沙 安康 濟南 山西 山西 海南 崇左 喀什

巨人網(wǎng)絡(luò)通訊聲明:本文標題《7個perl數(shù)組高級操作技巧分享》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    辽宁省| 陇南市| 共和县| 黄浦区| 萨嘎县| 社旗县| 鄱阳县| 西贡区| 临泽县| 嫩江县| 临夏县| 嘉禾县| 两当县| 邵武市| 那坡县| 台北县| 通化县| 珲春市| 炎陵县| 弥勒县| 历史| 康保县| 泾川县| 剑阁县| 威信县| 贵州省| 宝兴县| 汕尾市| 惠安县| 民和| 新化县| 抚远县| 贡嘎县| 宁波市| 盐边县| 金湖县| 白水县| 乡宁县| 黑龙江省| 东平县| 桐柏县|