OpenXE/classes/Components/Exporter/docs/csv-export.md
2021-05-21 08:49:41 +02:00

3.2 KiB

CSV-Exporter

Datei erstellen

<?php

use Xentral\Components\Database\Database;
use Xentral\Components\Exporter\Csv\CsvExporter;

/** @var Database $db */
$db = $container->get('Database');
$data = $db->yieldAll('SELECT e.* FROM employees AS e');

$filePath = tempnam(sys_get_temp_dir(), 'employees') . '.csv';

$exporter = new CsvExporter();
$exporter->export($filePath, $data);
Rückgabewerte
  • Die export() Methode liefert nichts zurück.
  • Die exportToResource() gibt die geöffnete Ressource zurück. Die Ressource muss manuell (mit fclose()) geschlossen werden. Der Dateizeiger ist auf EOF platziert.
Funktionsparameter

Beide export*()-Methoden nehmen die gleichen Parameter entgegen.

  • Als erster Parameter wird ein absoluter Dateipfad erwartet. Alternativ kann ein Stream Wrapper angegeben werden. Beispiele:

    • php://output um die CSV direkt auszugeben (echo).
    • php://memory um in den Arbeitsspeicher zu schreiben.
    • php://temp um in eine temporäre Datei zu schreiben.
  • Der zweite Parameter nimmt die Daten entgegen die als CSV exportiert werden sollen. Folgende Typen sind erlaubt:

    • array
    • Generator
    • Iterator
    • IteratorAggregate
Konstruktor-Parameter
  • Der erste Konstruktor-Parameter ist optional und nimmt die CSV-Konfiguration entgegen; siehe Erweiterte Beispiele > CSV konfigurieren.

Datei-Download erstellen

<?php

use Xentral\Components\Database\Database;
use Xentral\Components\Exporter\Csv\CsvExporter;

/** @var Database $db */
$db = $container->get('Database');
$data = $db->yieldAll('SELECT e.* FROM employees AS e');

$exporter = new CsvExporter();
$resource = $exporter->exportToResource('php://memory', $data);
rewind($resource);
$stat = fstat($resource);

header('Cache-Control: must-revalidate');
header('Pragma: must-revalidate');
header('Content-type: text/csv');
header('Content-Disposition: attachment; filename="employees.csv"');
header('Content-Length: ' . $stat['size']);
fpassthru($resource);
fclose($resource);

Erweiterte Beispiele

CSV konfigurieren

<?php

use Xentral\Components\Exporter\Csv\CsvConfig;
use Xentral\Components\Exporter\Csv\CsvExporter;

$csvConfig = new CsvConfig();
$csvConfig->setDelimiter(';');
$csvConfig->setEnclosure('"');
$csvConfig->setSourceCharset('UTF-8');
$csvConfig->setTargetCharset('ISO-8859-1');

$exporter = new CsvExporter($csvConfig);
$exporter->export($filePath, $data);

Daten zusammenführen

<?php

use Xentral\Components\Exporter\Csv\CsvExporter;
use Xentral\Components\Exporter\Collection\DataCollection;

$collection = new DataCollection($headline, $employees);

$exporter = new CsvExporter();
$exporter->export($filePath, $collection);

Daten formatieren

<?php

use Xentral\Components\Exporter\Csv\CsvExporter;
use Xentral\Components\Exporter\Collection\FormatterCollection;

$formatter = new FormatterCollection($data, function ($row) {
    $row['fullname'] = $row['firstname'] . ' ' . $row['lastname'];
    
    return $row;
});

$exporter = new CsvExporter();
$exporter->export($filePath, $formatter);

Statt einer anonymen Funktion (Closure) kann ein callable übergeben werden.