有時(shí)遇到各行或各列的長(zhǎng)度不一致時(shí)就麻煩了,雖然可以在R里面把文件按最長(zhǎng)的行(列)填充,但是不便,所以想起用perl去實(shí)現(xiàn)一個(gè)。
由逗號(hào)分隔的不定長(zhǎng)度的文本文件, 現(xiàn)要實(shí)現(xiàn)行列轉(zhuǎn)置, 即由
復(fù)制代碼 代碼如下:
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, , ,
以下是完整的代碼,供大家參考。
復(fù)制代碼 代碼如下:
#!/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)隨用。