perl對(duì)長(zhǎng)度不一文本的行列進(jìn)行置換的實(shí)現(xiàn)代碼
有時(shí)遇到各行或各列的長(zhǎng)度不一致時(shí)就麻煩了,雖然可以在R里面把文件按最長(zhǎng)的行(列)填充,但是不便,所以想起用perl去實(shí)現(xiàn)一個(gè)。
由逗號(hào)分隔的不定長(zhǎng)度的文本文件, 現(xiàn)要實(shí)現(xiàn)行列轉(zhuǎn)置, 即由
1,2,3,4,5,6,
7,8,9,
10,11,12,13,
轉(zhuǎn)換為:
1,7,10,
2,8,11,
3,9,12,
4, ,13,
5, , ,
6, , ,
以下是完整的代碼,供大家參考。
#!/usr/bin/perl -w
my @matrix;
my $max_len = 0;
while(<DATA>){
chomp;
s/,$//g;
my @fields = split /,/, $_;
my $len = @fields;
$max_len = $max_len > $len ? $max_len : $len;
push @matrix, [@fields];
}
for my $col (0..$max_len - 1){
for my $line (@matrix){
print $line->[$col] || ' ', ',';
}
print "\n";
}
__DATA__
1,2,3,4,5,6,
7,8,9,
10,11,12,13,
準(zhǔn)備學(xué)習(xí)下,自己動(dòng)手實(shí)現(xiàn)一遍,最好是做成模板,隨調(diào)隨用。
相關(guān)文章
Windows和Linux系統(tǒng)下perl連接SQL Server數(shù)據(jù)庫(kù)的方法
這篇文章主要介紹了Windows和Linux系統(tǒng)下perl連接SQL Server數(shù)據(jù)庫(kù)的方法,本文詳細(xì)的講解了Windows和Linux系統(tǒng)中perl如何連接Microsoft SQL Server數(shù)據(jù)庫(kù),需要的朋友可以參考下2014-10-10Perl從文件中讀取字符串的兩種實(shí)現(xiàn)方法
有時(shí)候我們需要從文件中讀取字符串,這里簡(jiǎn)單介紹下, 需要的朋友可以參考下2013-02-02Perl中使用dig和nali判斷DNS解析地址歸屬地是否一致腳本分享
這篇文章主要介紹了Perl中使用dig和nali判斷DNS解析地址歸屬地是否一致腳本分享,本文同時(shí)介紹了一個(gè)使用純真IP庫(kù)實(shí)現(xiàn)的Perl查詢工具,需要的朋友可以參考下2014-09-09perl產(chǎn)生隨機(jī)數(shù)實(shí)現(xiàn)代碼
Perl利用函數(shù)rand()和srand()為隨機(jī)數(shù)(更確切的說(shuō)是“偽隨機(jī)數(shù)”)字符串的生成提供了基本的工具2013-02-02