使用Perl Text :: CSV从数据库写入

我试图使用数据库查询将查询输出打印到CSV但无法将输出打印到单独的行.怎么办?

这是代码:

use warnings;
use DBI;
use strict;
use Text::CSV;

#set up file
my $csv = Text::CSV->new ( { binary => 1 } )  # should set binary attribute.
             or die "Cannot use CSV: ".Text::CSV->error_diag ();

open my $fh,">:encoding(utf8)","new.csv" or die "new.csv: $!";

#set up query
my $dbh = DBI->connect("DBI:mysql:db","name") or die ("Error:  $DBI::errstr");

my $sql = qq(select * from one_table join two_table using (primary_key));
my $query = $dbh->prepare($sql);
$query->execute;

#loop through returned rows of query and save each row as an array
while ( my (@row ) = $query->fetchrow_array ) {
    #print each row to the csv file
    $csv->print ($fh,[@row]);    
        # every line seems to be appended to same line in "new.csv"
        # tried adding "\n" to no avail 
    }
close $fh or die "new.csv: $!";

这必须是一个常见的用例,但无法找到有关新行问题的任何内容.

解决方法

我认为你的问题是你的所有CSV数据都在同一条线上?

您应该在CSV对象中设置eol选项:

my $csv = Text::CSV->new ( {
         binary => 1,# should set binary attribute.
         eol    => $/,# end of line character
}) or die "Cannot use CSV: ".Text::CSV->error_diag ();

此字符将附加到打印行的末尾.您也可以考虑不在每次迭代时从fetchrow调用中复制值,因为print需要数组引用.使用引用会更直接.

while (my $row = $query->fetchrow_arrayref) {
    ....
    $csv->print($fh,$row);

相关文章

1. 如何去重 #!/usr/bin/perl use strict; my %hash; while(...
最近写了一个perl脚本,实现的功能是将表格中其中两列的数据...
表的数据字典格式如下:如果手动写MySQL建表语句,确认麻烦,...
巡检类工作经常会出具日报,最近在原有日报的基础上又新增了...
在实际生产环境中,常常需要从后台日志中截取报文,报文的形...
最近写的一个perl程序,通过关键词匹配统计其出现的频率,让...