osmaviation / spreadsheet
A simple wrapper around PHP Spreadsheet
Installs: 10 368
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Requires
- cache/predis-adapter: ^1.0.0
- cache/redis-adapter: ^1.0.0
- cache/simple-cache-bridge: ^1.0.0
- illuminate/support: >=5.5
- phpoffice/phpspreadsheet: ^1.3.1
README
A simple Laravel abstraction to the PHPSpreadsheet (previously PHPExcel) library, ideal for writing XLSX (Excel) files.
Installing
composer require osmaviation/spreadsheet
Using
Via resolve
$filename = 'my-filename.xlsx'; resolve('spreadsheet')->create($filename, function ($excel) { $excel->sheet('Worksheet', function ($sheet) { $sheet->fromArray([ 'Foo', 'Bar', ], null, 'A1', true, false); }); });
Via facade
use OSMAviation\Spreadsheet\Facades\Spreadsheet; $filename = 'my-filename.xlsx'; Spreadsheet::create($filename, function ($excel) { $excel->sheet('Worksheet', function ($sheet) { $sheet->fromArray([ 'Foo', 'Bar', ], null, 'A1', true, false); }); });
Via injection
use OSMAviation\Spreadsheet\PhpSpreadsheet as Spreadsheet; class MyController { public function store(Spreadsheet $spreadsheet) { $filename = 'my-filename.xlsx'; $spreadsheet->create($filename, function ($excel) { $excel->sheet('Worksheet', function ($sheet) { $sheet->fromArray([ 'Foo', 'Bar', ], null, 'A1', true, false); }); }); } }
Saving the spreadsheet
$filename = 'some-folder/my-filename.xlsx'; Spreadsheet::create($filename, function ($excel) { $excel->sheet('Worksheet', function ($sheet) { // $sheet will be a PhpOffice\PhpSpreadsheet\Worksheet\Worksheet instance $sheet->fromArray([ 'Foo', 'Bar', ], null, 'A1', true, false); }); })->store('local');
Loading a file
Spreadsheet::load($filename, function ($excel) { $excel->sheet('Some existing sheet', function($sheet) { // }); });
You can also pass the disk name as the second argument to the load
method to load files from a different file system.
Spreadsheet::load($filename, 's3', function ($excel) { $excel->sheet('Some sheet', function($sheet) { // }); });
Accessing a PHPSpreadsheet spreadsheet
The callback for the create method will provide an instance of OSMAviation\Spreadsheet\Spreadsheet
which is a
convenience layer for creating worksheets. You can access the vendor spreadsheet by using the getSpreadsheet
method.
Spreadsheet::create($filename, function ($excel) { $vendorSheet = $excel->getSpreadsheet(); // returns a PhpOffice\PhpSpreadsheet\Spreadsheet instance })->store('local');