其它一些程式設計語言中,有函數ltrim和rtrim分別用於從字串開頭和末尾刪除空格和定位字元。 也有的提供了函數trim來刪除字串兩端的空白字元。Perl裡沒這些函數因為簡單的Regex替換就能實現這個目的(不過我確信CPAN有很多模組實現了這些函數)。事實上這太簡單了以至於成了帕金森瑣碎定理裡的一個顯著主題。
左側整理
ltrim或者lstrip從字串左側刪除空白字元:
複製代碼 代碼如下:
$str =~ s/^\s+//;
從字串開頭^開始匹配一個或者多個空白字元(\s+),並將之替換成Null 字元。
右側整理
rtrim或者rstrip從字串右側刪除空白字元:
複製代碼 代碼如下:
$str =~ s/\s+$//;
匹配一個或者多個空白字元(\s+)直到字串末尾($),並將之替換成Null 字元。
整理兩端
trim刪除字串兩端的空白字元:
複製代碼 代碼如下:
$str =~ s/^\s+|\s+$//g
將上面兩個Regex用或記號|連起來,並在最後增加/g用以全域地執行替換操作(反覆多次)。
封裝在函數裡
如果你不想在代碼中看到這些結構,你可以在代碼裡添加這些函數:
複製代碼 代碼如下:
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提供了函數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>
預設它整理兩側,你不需要提供參數。 我覺得,自己實現ltrim和rtrim會清晰些。
Text::Trim
另一個模組Text::Trim提供了3個函數,但是它極度採納了Perl風格的寫法,可能到了有些危險的地步。
如果你調用它並將傳回值用在print語句或者賦給一個變數,它會返回整理過的字串,並保持原始字串不變。
複製代碼 代碼如下:
use Text::Trim qw(trim);
my $z = " abc ";
printf "<%s>\n", trim($z); # <abc>
printf "<%s>\n", $z; # < abc >
另一方面,如果你在空白上下文調用它,亦即不使用傳回值,trim函數就會修改參數,產生類似chomp的行為。
複製代碼 代碼如下:
use Text::Trim qw(trim);
my $z = " abc ";
trim $z;
printf "<%s>\n", $z; # <abc>