【发布时间】:2013-10-21 10:16:26
【问题描述】:
我正在尝试使用数据库查询将查询输出打印到 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: $!";
这一定是一个常见的用例,但找不到任何关于新行问题的信息。
【问题讨论】:
-
您在
qq()中使用(),这很奇怪(但似乎出于某种原因可以使用!),并且行尾没有分号,这应该会导致语法错误。无论出于何种原因,您都不应该尝试将您的源代码输入一个问题:始终剪切和粘贴。 -
添加了分号!代码必须匿名/通用化才能有意义。剪切和粘贴实际代码是行不通的。 NB。 MySQL 语句中的括号是否由 qq() 限制似乎总是对我有用!
-
使用
qq()(以及许多其他 perl 运算符,例如m//、s///、qr//等),您可以将括号更改为几乎任何其他标点符号。这减少了转义字符的需要,例如m/\/usr\/bin\//可能是m#/usr/bin/#。但是在这种情况下,qq()似乎可以处理 inside 的括号,只要它们是平衡的。我不知道。其中一个我不确定是否真的有用的边缘案例,但是一个有趣的琐事。 :)