【发布时间】:2018-08-01 14:20:23
【问题描述】:
我正在尝试将数据写入新的 CSV 文件。我知道如何创建新文件以及如何从旧文件中收集我想要的数据,但我不确定如何将收集到的数据实际写入新文件。我希望我打印的列也写入新的 CSV 文件。这是我目前所拥有的:
use strict;
use warnings;
use Text::CSV_XS;
my @data;
my $file = 'FinalTest.csv'; #original file
my $newfile = 'filteredData.csv'; #new file
my $csv = Text::CSV_XS->new({ binary => 1 });
open my $fh, '<', $file or die "Could not open $file: $!";
my $header = $csv->getline($fh)
or die("No header\n");
$csv->column_names(@$header); #removes header row
while( my $row = $csv->getline($fh) ) {
push @data, $row;
printf "$row->[0]\t";
printf "$row->[1]\t";
printf "$row->[2]\t";
printf "$row->[3]\t";
printf "$row->[13]\n";
}
open my $newfile, '>', $newfile or die "Could not write $newfile"; #create new file
【问题讨论】:
-
为什么不干脆做:
./script.pl > new_file.csv? -
在this post中写入CSV的完整简单示例