Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/liuggio/ExcelBundle
Excel integration in Symfony2 thanks to https://github.com/PHPOffice/PHPExcel library
https://github.com/liuggio/ExcelBundle
Last synced: 3 months ago
JSON representation
Excel integration in Symfony2 thanks to https://github.com/PHPOffice/PHPExcel library
- Host: GitHub
- URL: https://github.com/liuggio/ExcelBundle
- Owner: liuggio
- License: mit
- Created: 2011-11-24T16:45:02.000Z (over 12 years ago)
- Default Branch: master
- Last Pushed: 2022-11-25T23:50:31.000Z (over 1 year ago)
- Last Synced: 2024-04-06T13:41:51.235Z (3 months ago)
- Language: PHP
- Homepage: www.welcometothebundle.com
- Size: 109 KB
- Stars: 370
- Watchers: 24
- Forks: 142
- Open Issues: 18
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Lists
- awesome-symfony - ExcelBundle - Excel integration in Symfony2 thanks to https://github.com/PHPOffice/PHPExcel library. (Miscellaneous)
- awesome-symfony - ExcelBundle - Excel integration in Symfony2 thanks to https://github.com/PHPOffice/PHPExcel library. (Miscellaneous)
README
Symfony2 Excel bundle
============This bundle permits you to create, modify and read excel objects.
[![Build Status](https://travis-ci.org/liuggio/ExcelBundle.png)](https://travis-ci.org/liuggio/ExcelBundle)
[![Total Downloads](https://poser.pugx.org/liuggio/ExcelBundle/downloads.png)](https://packagist.org/packages/liuggio/ExcelBundle)
[![Latest Stable Version](https://poser.pugx.org/liuggio/ExcelBundle/v/stable.png)](https://packagist.org/packages/liuggio/ExcelBundle)
[![Latest Unstable Version](https://poser.pugx.org/liuggio/ExcelBundle/v/unstable.png)](https://packagist.org/packages/liuggio/ExcelBundle)## License
[![License](https://poser.pugx.org/liuggio/ExcelBundle/license.png)](LICENSE)
## Version 2
This is the **shiny** new version.
There is a big BC with the 1.* version, but **unit tests**, **functional tests**, and **the new factory** is very simple to use.### Version 1.*
If you have installed an old version, and you are happy to use it, you could find documentation and files
in the [tag v1.0.6](https://github.com/liuggio/ExcelBundle/releases/tag/v1.0.6),
[browse the code](https://github.com/liuggio/ExcelBundle/tree/cf0ecbeea411d7c3bdc8abab14c3407afdf530c4).### Things to know:
CSV is faster so if you have to create simple xls file,
I encourage you to use the built-in function for csv: http://php.net/manual-lookup.php?pattern=csv&lang=en&scope=quickref## Installation
**1** Add to composer.json to the `require` key
``` shell
$composer require liuggio/excelbundle
```**2** Register the bundle in ``app/AppKernel.php``
``` php
$bundles = array(
// ...
new Liuggio\ExcelBundle\LiuggioExcelBundle(),
);
```## TL;DR
- Create an empty object:
``` php
$phpExcelObject = $this->get('phpexcel')->createPHPExcelObject();
```- Create an object from a file:
``` php
$phpExcelObject = $this->get('phpexcel')->createPHPExcelObject('file.xls');
```- Create a Excel5 and write to a file given the object:
```php
$writer = $this->get('phpexcel')->createWriter($phpExcelObject, 'Excel5');
$writer->save('file.xls');
```- Create a Excel5 and create a StreamedResponse:
```php
$writer = $this->get('phpexcel')->createWriter($phpExcelObject, 'Excel5');
$response = $this->get('phpexcel')->createStreamedResponse($writer);
```- Create a Excel file with an image:
```php
$writer = $this->get('phpexcel')->createPHPExcelObject();
$writer->setActiveSheetIndex(0);
$activesheet = $writer->getActiveSheet();$drawingobject = $this->get('phpexcel')->createPHPExcelWorksheetDrawing();
$drawingobject->setName('Image name');
$drawingobject->setDescription('Image description');
$drawingobject->setPath('/path/to/image');
$drawingobject->setHeight(60);
$drawingobject->setOffsetY(20);
$drawingobject->setCoordinates('A1');
$drawingobject->setWorksheet($activesheet)
```## Not Only 'Excel5'
The list of the types are:
1. 'Excel5'
2. 'Excel2007'
3. 'Excel2003XML'
4. 'OOCalc'
5. 'SYLK'
6. 'Gnumeric'
7. 'HTML'
8. 'CSV'## Example
### Fake Controller
The best place to start is the fake Controller at `Tests/app/Controller/FakeController.php`, that is a working example.
### More example
You could find a lot of examples in the official PHPExcel repository https://github.com/PHPOffice/PHPExcel/tree/develop/Examples
### For lazy devs
``` php
namespace YOURNAME\YOURBUNDLE\Controller;use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Symfony\Component\HttpFoundation\ResponseHeaderBag;class DefaultController extends Controller
{public function indexAction($name)
{
// ask the service for a Excel5
$phpExcelObject = $this->get('phpexcel')->createPHPExcelObject();$phpExcelObject->getProperties()->setCreator("liuggio")
->setLastModifiedBy("Giulio De Donato")
->setTitle("Office 2005 XLSX Test Document")
->setSubject("Office 2005 XLSX Test Document")
->setDescription("Test document for Office 2005 XLSX, generated using PHP classes.")
->setKeywords("office 2005 openxml php")
->setCategory("Test result file");
$phpExcelObject->setActiveSheetIndex(0)
->setCellValue('A1', 'Hello')
->setCellValue('B2', 'world!');
$phpExcelObject->getActiveSheet()->setTitle('Simple');
// Set active sheet index to the first sheet, so Excel opens this as the first sheet
$phpExcelObject->setActiveSheetIndex(0);// create the writer
$writer = $this->get('phpexcel')->createWriter($phpExcelObject, 'Excel5');
// create the response
$response = $this->get('phpexcel')->createStreamedResponse($writer);
// adding headers
$dispositionHeader = $response->headers->makeDisposition(
ResponseHeaderBag::DISPOSITION_ATTACHMENT,
'stream-file.xls'
);
$response->headers->set('Content-Type', 'text/vnd.ms-excel; charset=utf-8');
$response->headers->set('Pragma', 'public');
$response->headers->set('Cache-Control', 'maxage=1');
$response->headers->set('Content-Disposition', $dispositionHeader);return $response;
}
}
```## Contributors
the [list of contributors](https://github.com/liuggio/ExcelBundle/graphs/contributors)
## Contribute
1. fork the project
2. clone the repo
3. get the coding standard fixer: `wget http://cs.sensiolabs.org/get/php-cs-fixer.phar`
4. before the PullRequest you should run the coding standard fixer with `php php-cs-fixer.phar fix -v .`