如何在Symfony中将实体导出为CSV?

时间:2014-01-15 00:51:32

标签: php symfony export-to-csv

我使用以下代码输出CSV但运行时我得到一个空白屏幕。基本上我的困惑是DoctrineORMQuerySourceIterator,因为我不知道如何正确使用它。我假设我必须列出属性名称????

我正在使用Sonata Exporter:

https://github.com/sonata-project/exporter

<?php

$repository = $this->getDoctrine()->getRepository('MainReferralCaptureBundle:Referral');
$referrals = $repository->createQueryBuilder('r')->select('r.pLastName, r.pFirstName')->getQuery();

// $referrals2 = $referrals->getResult();
// var_dump($referrals2);

$data = array(
    0 => array('name' => 'Jack'),
    1 => array('name' => 'Jill')
);

// Pick a format to export to
$format = 'csv';

// Filename
$filename = 'referral.csv';

// Set Content-Type
$content_type = 'text/csv';

// Location to Export this to
$export_to = 'php://output';

// Data to export
$exporter_source = new \Exporter\Source\DoctrineORMQuerySourceIterator($referrals, array('pLastName, pFirstName'));

// Get an Instance of the Writer
$exporter_writer = '\Exporter\Writer\\' . ucfirst($format) . 'Writer';

$exporter_writer = new $exporter_writer($export_to);

// Set the right headers
header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
header('Content-Description: File Transfer');
header('Content-type: ' . $content_type);
header('Content-Disposition: attachment; filename=' . $filename . ';');
header('Expires: 0');
header('Pragma: public');

// Export to the format
\Exporter\Handler::create($exporter_source, $exporter_writer)->export();

2 个答案:

答案 0 :(得分:3)

DoctrineORMQuerySourceIterator的secound参数是一个属性名称数组,如下所示:

['Column name in the output' => 'fieldName', 'Something' => 'address.street']

正如您在source code中看到的,它实际上使用Property Accessor组件来访问数据(您可以在那里找到更多示例)。

如果您想从数据库中导出原始数据,我建议使用PDOStatementSourceIteratorDoctrineDBALConnectionSourceIterator,因为它们更快。前者需要PDOStatement,另一个需要连接,查询和参数数组(您可以在链接的源代码中看到它)作为构造函数参数。

答案 1 :(得分:1)

使用CsvWriter的工作示例:

$format = 'csv';
$exportTo = 'php://output';
$exporterWriter = '\Exporter\Writer\\' . ucfirst($format) . 'Writer';

$data = $repository->createQueryBuilder('r')->getQuery();
$fields = array('Last Name' => 'pLastName', 'First Name' => 'pFirstName');
$source = new DoctrineORMQuerySourceIterator($data, $fields);
$writer = new $exporterWriter($exportTo);

Handler::create($source, $writer)->export();

在回答您的问题之前,请原谅。