Perl刪除前導(dǎo)和拖尾空白(刪除左右空格、空白字符)
其它一些編程語言中,有函數(shù)ltrim和rtrim分別用于從字符串開頭和末尾刪除空格和制表符。 也有的提供了函數(shù)trim來刪除字符串兩端的空白字符。Perl里沒這些函數(shù)因為簡單的正則表達式替換就能實現(xiàn)這個目的(不過我確信CPAN有很多模塊實現(xiàn)了這些函數(shù))。事實上這太簡單了以至于成了帕金森瑣碎定理里的一個顯著主題。
左側(cè)整理
ltrim或者lstrip從字符串左側(cè)刪除空白字符:
$str =~ s/^\s+//;
從字符串開頭^開始匹配一個或者多個空白字符(\s+),并將之替換成空字符。
右側(cè)整理
rtrim或者rstrip從字符串右側(cè)刪除空白字符:
$str =~ s/\s+$//;
匹配一個或者多個空白字符(\s+)直到字符串末尾($),并將之替換成空字符。
整理兩端
trim刪除字符串兩端的空白字符:
$str =~ s/^\s+|\s+$//g
將上面兩個正則表達式用或記號|連起來,并在最后增加/g用以全局地執(zhí)行替換操作(反復(fù)多次)。
封裝在函數(shù)里
如果你不想在代碼中看到這些結(jié)構(gòu),你可以在代碼里添加這些函數(shù):
sub ltrim { my $s = shift; $s =~ s/^\s+//; return $s };
sub rtrim { my $s = shift; $s =~ s/\s+$//; return $s };
sub trim { my $s = shift; $s =~ s/^\s+|\s+$//g; return $s };
使用時像這樣:
my $z = " abc ";
printf "<%s>\n", trim($z); # <abc>
printf "<%s>\n", ltrim($z); # <abc >
printf "<%s>\n", rtrim($z); # < abc>
String::Util
String::Util
要是實在不想拷貝那些東西,你可以安裝一個模塊。
例如String::Util提供了函數(shù)trim,你可以如下使用:
use String::Util qw(trim);
my $z = " abc ";
printf "<%s>\n", trim( $z ); # <abc>
printf "<%s>\n", trim( $z, right => 0 ); # <abc >
printf "<%s>\n", trim( $z, left => 0 ); # < abc>
默認它整理兩側(cè),你不需要提供參數(shù)。 我覺得,自己實現(xiàn)ltrim和rtrim會清晰些。
Text::Trim
另一個模塊Text::Trim提供了3個函數(shù),但是它極度采納了Perl風(fēng)格的寫法,可能到了有些危險的地步。
如果你調(diào)用它并將返回值用在print語句或者賦給一個變量,它會返回整理過的字符串,并保持原始字符串不變。
use Text::Trim qw(trim);
my $z = " abc ";
printf "<%s>\n", trim($z); # <abc>
printf "<%s>\n", $z; # < abc >
另一方面,如果你在空白上下文調(diào)用它,亦即不使用返回值,trim函數(shù)就會修改參數(shù),產(chǎn)生類似chomp的行為。
use Text::Trim qw(trim);
my $z = " abc ";
trim $z;
printf "<%s>\n", $z; # <abc>
相關(guān)文章
perl 讀取所需文件的路徑,然后打開相應(yīng)的文件
perl,讀取所需文件的路徑,然后打開相應(yīng)的文件,并對文件中的DNA序列進行計數(shù),substr函數(shù)對長字符串的片段化處理功能2013-03-03