perl语言学习系列-----map、grep函数处理数组

由于在代码中经常用到foreach循环遍历数组,perl中还存在两个更为简单的遍历数组的函数。

1.map函数

a.语法规则

语法:map EXPR,LIST或map BLOCK LIST
返回值:列表上下文为列表,标量上下文是列表的元素个数
功能描述:map函数的功能主要是遍历list,每次遍历执行一次EXPR(表达式)或者BLOCK指
令块,最后返回EXPR计算后BLOCK最后一行代码执行后的返回值组成的列表。

注意:map与foreach类似,$_ 为遍历过程中数组或列表的别名,如果遍历过程中更改了$_,则对应数组的值会相应改变。

b.map函数示例

@number=map $_+10,1..20;    #将1..20的列表的每个元素加10,然后赋值给@number数组

map $_+=10,1..20 ;    #列表元素都加10

@number=map {split//} 1..20 ;   #将1..20列表的元素切成单个字符,赋值给数组,最后返回的数组是1-9,1,0,1,1一直到1,9,2,0

map {push @arr,$_ if $_>60} @number;      #将数组中大于60的元素选出

2.grep 函数

a.语法规则

语法:grep EXPR,LIST或grep BLOCK list
返回值:列表上下文返回列表,标量上下文返回列表元素个数
功能描述:返回LIST中使EXPR的值或者BLOCK里最后一行代码运算结果为真的值。

b.grep函数示例

@number60=grep $_ > 60, @number;   #找出数组中大于60的元素  
@seq_200=grep length($_) > 200, @seq; #找出数组中大于200的字符串

# 找出@seq_200里G数目大于9的元素
@seq9=grep {@base=split//,$_; (grep $_ eq "G" , @base) > 9} @seq_200

#找出@seq_200里G数目大于9的元素
@seq=grep ((grep $_ eq "G", split//,$_) > 9, @seq_200)

3.map与grep函数的异与同

两者都可以进行数组的遍历,且语法结构类似,相较于foreach都有返回值。map和grep语法中的第二种中的BLOCK可以是多行代码,map的返回值是多行代码中的最后一行的返回值。grep则根据BLOCK返回值的真假来决定是否返回列表的值,真则返回,反之不返回。

4.map与grep函数示例演示

随机生成20条长度为50个碱基的DNA序列,筛选出其中G数目在9个以上的序列并输出到屏幕。

@base=qw(A T C G);
@seq_20=map {
                    @base_50= map {$base[rand 4]} 1..50;
                     $seq_50=join "",@base;
} 1..20  ;
@seq_g9=grep {
                           $G_number= grep $_ eq "G", split//;
                           $G_number > 9
} @seq_20;

map {print $_,"\n"} @seq_g9; 

也可以简写为如下:

@base=qw(A T C G)
map {print $_,"\n"} (grep { (grep $_ eq "G", split//) > 9 }  map {join ("", map {$base[rand 4] } 1..50)} (1..20))

map与grep 是将循环变成了函数,使其能够有返回值,函数的返回值可以作为另一个函数的操作数,Perl语言又规定所有的函数操作数都写在函数右侧。如此,就可以无限地在函数的返回之前加函数,无需中间变量。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,525评论 6 507
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,203评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,862评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,728评论 1 294
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,743评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,590评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,330评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,244评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,693评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,885评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,001评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,723评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,343评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,919评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,042评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,191评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,955评论 2 355

推荐阅读更多精彩内容