yectep / phpspreadsheet-bundle
A Symfony bundle to integrate with PHPOffice's PhpSpreadsheet library
Installs: 1 872 444
Dependents: 4
Suggesters: 0
Security: 0
Stars: 57
Watchers: 4
Forks: 24
Open Issues: 6
Type:symfony-bundle
Requires
- php: >=7.2
- phpoffice/phpspreadsheet: ~1.16
- symfony/framework-bundle: ^4.0|^5.0|^6.0|^7.0
README
This bundle integrates your Symfony 4/5/6/7 app with the PHPOffice PhpSpreadsheet productivity library.
Requirements
This bundle requires, in addition to prerequisites of each PHPOffice library:
* PHP 7.2 or higher
* Symfony 4 or higher
Note: Tags older than v1.0.0 (e.g. v0.2.0) are no longer supported due to deprecated status for both PHP <= 7.1 and Symfony <= 4.4.
Installation
Use composer to require the latest stable version.
composer require yectep/phpspreadsheet-bundle
If you're not using Flex, enable the bundle in your AppKernel.php
or bundles.php
file.
$bundles = array( [...] new Yectep\PhpSpreadsheetBundle\PhpSpreadsheetBundle(), );
Usage
This bundle enables the phpoffice.spreadsheet
service.
See also the official PHPOffice PhpSpreadsheet documentation.
createSpreadsheet()
Creates an empty \PhpOffice\PhpSpreadsheet\Spreadsheet
object, or, if an optional
$filename
is passed, instantiates the \PhpOffice\PhpSpreadsheet\IOFactory
to
automatically detect and use the appropriate IWriter
class to read the file.
// In your controller $newSpreadsheet = $this->get('phpoffice.spreadsheet')->createSpreadsheet(); $existingXlsx = $this->get('phpoffice.spreadsheet')->createSpreadsheet('/path/to/file.xlsx');
createReader(string
$type)
Returns an instance of the \PhpOffice\PhpSpreadsheet\Reader
class of the given $type
.
Types are case sensitive. Supported types are:
Xlsx
: Excel 2007Xls
: Excel 5/BIFF (95)Xml
: Excel 2003 XMLSlk
: Symbolic Link (SYLK)Ods
: Open/Libre Office (ODS)Csv
: CSVHtml
: HTML
$readerXlsx = $this->get('phpoffice.spreadsheet')->createReader('Xlsx'); $spreadsheet = $readerXlsx->load('/path/to/file.xlsx');
createWriter(Spreadsheet
$spreadsheet, string
$type)
Given a \PhpOffice\PhpSpreadsheet\Spreadsheet
object and a writer $type
, returns
an instance of a \PhpOffice\PhpSpreadsheet\Writer
class for that type.
In addition the the read types above, these types are additionally supported for writing, if the appropriate PHP libraries are installed.
Tcpdf
Mpdf
Dompdf
$spreadsheet = $this->get('phpoffice.spreadsheet')->createSpreadsheet(); $spreadsheet->getActiveSheet()->setCellValue('A1', 'Hello world'); $writerXlsx = $this->get('phpoffice.spreadsheet')->createWriter($spreadsheet, 'Xlsx'); $writerXlsx->save('/path/to/destination.xlsx');
Roadmap and Contributions
Contributions are more than welcome. Fork the project, and submit a PR when you're done.
Remaining todos include:
- Tests and test coverage
- TravisCI
- Improved documentation
Symfony serializer
If you are migrating from Symfony Serializer component + CSV encoder - you can use code like
$spreadsheet = $this->get('phpoffice.spreadsheet')->createSpreadsheet(); $sheet = $spreadsheet->getActiveSheet(); $sheet->setTitle($this->filterVars['wareCategory']->getTitle()); $columnsMap = []; $lineIndex = 2; foreach ($data as $line) { foreach ($line as $columnName=>$columnValue) { if (is_int($columnIndex = array_search($columnName, $columnsMap))) { $columnIndex++; } else { $columnsMap[] = $columnName; $columnIndex = count($columnsMap); } $sheet->getCellByColumnAndRow($columnIndex, $lineIndex)->setValue($columnValue); } $lineIndex++; } foreach ($columnsMap as $columnMapId=>$columnTitle) { $sheet->getCellByColumnAndRow($columnMapId+1, 1)->setValue($columnTitle); } $writer = $this->get('phpoffice.spreadsheet')->createWriter($spreadsheet, 'Xlsx'); ob_start(); $writer->save('php://output'); $excelOutput = ob_get_clean(); return new Response( $excelOutput, 200, [ 'content-type' => 'text/x-csv; charset=windows-1251', 'Content-Disposition' => 'attachment; filename="price.xlsx"' ] );