麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > Perl > 正文

Perl split字符串分割函數用法指南

2020-10-31 15:19:03
字體:
來源:轉載
供稿:網友

本文和大家重點討論一下Perl split函數的用法,Perl中的一個非常有用的函數是Perl split函數-把字符串進行分割并把分割后的結果放入數組中。這個Perl split函數使用規則表達式(RE),如果未特定則工作在$_變量上。

Perl split函數

Perl中的一個非常有用的函數是Perl split函數-把字符串進行分割并把分割后的結果放入數組中。這個Perl split函數使用規則表達式(RE),如果未特定則工作在$_變量上。

Perl split函數可以這樣使用: 

復制代碼 代碼如下:

$info="Caine:Michael:Actor:14,LeafyDrive"; 
@personal=split(/:/,$info); 


其結果是:@personal=("Caine","Michael","Actor","14,LeafyDrive");

◆如果我們已經把信息存放在$_變量中,那么可以這樣:

復制代碼 代碼如下:

@personal=split(/:/);

如果各個域被任何數量的冒號分隔,可以用RE代碼進行分割: 

復制代碼 代碼如下:

$_="Capes:Geoff::Shotputter:::BigAvenue"; 
@personal=split(/:+/); 

其結果是:@personal=("Capes","Geoff","Shotputter","BigAvenue");

但是下面的代碼:

復制代碼 代碼如下:

$_="Capes:Geoff::Shotputter:::BigAvenue"; 
@personal=split(/:/);

的結果是:@personal=("Capes","Geoff","","Shotputter","","","BigAvenue");

◆這個Perl split函數中單詞可以被分割成字符,句子可以被分割成單詞,段落可以被分割成句子:

復制代碼 代碼如下:

@chars=split(//,$word);
@words=split(//,$sentence); 
@sentences=split(//./,$paragraph); 

在第一句中,空字符串在每個字符間匹配,所以@chars數組是一個字符的數組。>>

//之間的部分表示split用到的正則表達式(或者說分隔法則)
/s是一種通配符,代表空格
+代表重復一次或者一次以上。
所以,/s+代表一個或者一個以上的空格。
split(//s+/,$line)表示把字符串$line,按空格為界分開。
比如說,$line="你好朋友歡迎光臨我的網站VeVB.COm";
split(//s+/,$line)后得到:
你好朋友歡迎訪問我的網站VeVB.COm

一般用法: @somearray = split(/:+/, $string ); #括號可以不要。  若不指定$string, 則對默認變量$_操作, 兩斜線間為分割符,可以用正則表達式,強悍異常。

在perl手冊里,有一個用法不多見。即: split /PATTERN/, EXPR, LIMIT;  關鍵就是這個LIMIT參數,可以節省不少事情。 如果使用了LIMIT,且是正數,表示分割成不多于LIMIT指定的數目的域。If LIMIT is unspecified or zero, trailing null fields are stripped (which potential users of pop would do well to remember). If LIMIT is negative, it is treated as if an arbitrarily large LIMIT had been specified. Note that splitting an EXPR that evaluates to the empty string always returns the empty list, regardless of the LIMIT specified.

通過制定LIMIT,可以在很長(分割產生幾萬個元素or域)的行分割操作中,只返回關鍵的前幾列的域值,減少了內存使用及時間消耗。比如一般的基因型數據,第一列通常是材料命名,需要通過材料名的判斷取舍,這時候就可以這樣用。 my ($firstfield) = split //t/, $someline, 1;  如果需要前面幾列的值,這樣的方式對大文件效率很好: my (undef, $var1, undef, undef, undef, $var2)=split //t/, $someline, 6;

有網友對這種方式做了測試,顯示較好。引用如下:
>>>
一個文件,每行都有18項,各項之間用/t分割,使用時用到了第6項,折騰了幾種用法

復制代碼 代碼如下:

my @array = split("/t",$_); my $var = $array[6];   測試文件平均用時8.2s
 my($var) = (split("/t",$_))[6];  測試平均用時5.1s
 my(undef,undef,undef,undef,undef,undef,$var) = split("/t",$_); 平均用時3.53s
 my(undef,undef,undef,undef,undef,undef,$var) = split("/t",$_,7);平均用時3.52s
 my $var = (split("/t",$_,7))[6]; 平均用時3.53s

看來后3種才是王道,如果需要使用多項也可以進行進行適當的變動。不過兩項如果跨度比較大,3,4應該是不錯選擇,5就只能用中間數組。

自己動手測試下吧。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 中文字幕在线观看精品 | 国产青草视频在线观看视频 | 成人免费看毛片 | 成人免费乱码大片a毛片视频网站 | 久久999久久| 91情侣在线偷精品国产 | 羞羞视频免费观看网站 | 久久经典国产视频 | 国产在线精品区 | 免费淫视频 | 国产精品欧美久久久久一区二区 | 免费毛片儿 | 久久久久久久一区二区 | 亚洲精品一区二区三区在线看 | 亚洲一区二区观看播放 | 成人免费自拍视频 | 成人午夜视频在线观看免费 | 国产成人在线观看免费网站 | 九九热久久免费视频 | 国产色爱综合网 | 成人爱爱电影 | 18一20岁一级毛片 | 成人在线视频免费 | 亚洲精品自在在线观看 | 成人午夜网址 | 亚洲最大中文字幕 | 圆产精品久久久久久久久久久 | 国产成人精品二区 | 免费a级毛片永久免费 | 一级α片免费看刺激高潮视频 | 国产视频在线免费观看 | 久久精品国产99国产精品亚洲 | 国产成人网| 国产精品视频yy9299一区 | 国产亚洲精品久久久久久久软件 | 欧产日产国产精品99 | 欧美一级性| 亚洲精久久 | 久久久久国产精品久久久久 | 精品国产91一区二区三区 | 黄色片免费看网站 |