#New to v0.3.x
- Possibility to call all native PHPExcel methods
- seperator config value for label formatting (default is
-
) - loadView supports
->withKey('value')
&->with('key', 'value')
to set view data - Multiple sheets with support for a different view per sheet (or share the view)
- CSV import fix
- Date formatting fix
loadView()
inline styles parsing (including style, rowspan, colspan, align, valign)store()
can return information about the storage or can be followed by->export()
#Installation
Require this package in your composer.json
and update composer. This will download the package and PHPExcel of PHPOffice.
"maatwebsite/excel": "dev-master"
After updating composer, add the ServiceProvider to the providers array in app/config/app.php
'Maatwebsite\Excel\ExcelServiceProvider',
You can use the facade for shorter code. Add this to your aliasses:
'Excel' => 'Maatwebsite\Excel\Facades\Excel',
#Exporting
For creating an Excel file use:
Excel::create('ExcelName')
->sheet('SheetName')
->with(array(
array('data1', 'data2'),
array('data3', 'data4')
))
->export('xls');
Multiple sheets are allowed
Excel::create('ExcelName')
->sheet('SheetName')
->with(array('data', 'data'))
->sheet('SheetName')
->with(array('data', 'data'))
->export('xls');
Export as CSV by using:
->export('csv');
Export as Excel2007 by using:
->export('xlsx');
#Export from View file
It's possible to export a blade view file to xls or csv. The view file must be a table.
Use loadView()
with a view file and data to be used inside the view.
Excel::loadView('folder.file', array('key' => 'value'))->export('xls');
Alternatively you can use with('key', 'value')
or withKey('value')
as view data setters.
Excel::loadView('folder.file')
->with('first', 'value1')
->withSecond('value2')
->export('xls');
If you want to give the file a name chain setTitle()
after the loadView()
Excel::sheet('SheetName')->loadView('folder.file', array('key' => 'value'))
->setTitle('Title')
->export('xls');
If you want to create multiple cheats and share or use different views for these seperate sheets, you should call the closure
Excel::loadView('excel.reports')
->sheet('Daily', function($sheet) use($dailyReports) {
$sheet->withReports($dailyReports);
})->sheet('Weekly', function($sheet) use($weeklyReports) {
$sheet->withReports($weeklyReports);
})->setTitle('Reports')->export('xls');
Optionally you can change the view inside the closure.
Excel::sheet('Daily', function($sheet) use($dailyReports) {
$sheet->loadView('excel.reports.daily');
$sheet->withReports($dailyReports);
})->sheet('Weekly', function($sheet) use($weeklyReports) {
$sheet->loadView('excel.reports.weekly');
$sheet->withReports($weeklyReports);
})->setTitle('Reports')->export('xls');
Closures are only accepted when using a view.
To change the sheet's orientation, use $sheet->setOrientation('landscape')
It possible to use some basic styling inside the table.
HTML tags <strong>, <i> and <b>
are supported at this moment.
Table attributes (align, valign, rowspan & colspan
) will be properly parsed.
Most of the inline styles are parsed (style="background: #000000"):
Style tag name | Value |
---|---|
background | #000000 |
color | #FFFFFF |
font-weight | bold |
font-style | italic |
font-weight | bold |
font-size | 20px |
font-family | Open Sans |
text-decoration | underline / line-through |
text-align | center/left/right/justify |
vertical-align | top/middle/bottom/justify |
borders | 1px dashed #CCC |
border-* | 1px dashed #CCC |
#Store to server
To store the file to the server use store($extension, $path)
The path is optional, when this is empty, the default setting in the config will be used.
$file = Excel::loadView('folder.file', array('data'))
->setTitle('Title')
->sheet('SheetName')
->store('xls');
The store($ext, $path, true)
method returns information about the stored file (filename, location, extension, ...);
When the third parameter is false, it's possible to chain other methods. This example will store and export the same file:
$file = Excel::loadView('folder.file', array('data'))
->setTitle('Title')
->sheet('SheetName')
->store('xls')
->export('xls');
#Freeze / lock rows and columns
To freeze the first row of the sheet:
->freezeFirstRow()
To freeze the first column of the sheet:
->freezeFirstColumn()
To freeze the first row and first column of the sheet:
->freezeFirstRowAndColumn()
Freeze based on coordinate
->setFreeze('B1')
#Importing
To import CSV data:
Excel::load('file.csv')->toArray();
Optionally you can select columns, by their column index.
An empty select()
, or no select at all, means we will return all columns
Excel::load('file.csv')->select(array(1, 2))->toArray();
If the first row is the table heading, you can give the load()
method an extra parameter. This will make sure the first row is interpreted as heading. These seperate columns values will be used as array indices. Now you can select columns by their name. Note that the string will be lowercase and spaces will be replaced by -
.
Excel::load('file.csv', true)->select(array('column1', 'column2'))->toArray();
To change the input encoding (default is UTF8), use the third parameter of load()
Excel::load('file.csv', false, 'ISO-8859-1')->toArray();
The delimiter can be changed right after the file load with setDelimiter()
. The default delimiter is ,
, which has been set in the config file
Excel::load('file.csv')->setDelimiter(';')->toArray();
By default cells with formulas will not be calculated. If you want to calculate them, use the calculate()
chain. You can change the default inside the config.
Excel::load('file.xls')->calculate()->toArray();
By default cells will date/timestamps will be parsed to a PHP date Object and converted to Y-m-d.
You can disable this feature by using formatDates(false)
Excel::load('file.xls')->formatDates(false)->toArray();
The date format can be changed by using setDateFormat('Y-m-d')
. You can use all PHP Datetime formats;
Excel::load('file.xls')->setDateFormat('Y-m-d')->toArray();
Optionally you can use Carbon to format the date. Use useCarbon($methodName)
Excel::load('file.xls')->useCarbon('diffForHumans')->toArray();
If you want to limit the data which will be parsed, use limit()
.
Excel::load('file.csv')->limit(10)->toArray();
If you want to output the loaded data to an object, use toObject()
Excel::load('file.csv')->toObject();
For developping purposes you can choose to dump the returned parsed file to a readable array:
Excel::load('file.csv')->dump();
#Converting
To convert from one filetype to another, use convert()
:
return Excel::load('file.csv')->convert('xls');
#Cell and range formatting
If you want to format a certain column or range, you can use setColumnFormat(array())
.
Use the column coordinate or range as array index and use the format code as array value.
Example to get two leading zeros before the number for one column
->setColumnFormat(array(
'A' => '0000'
))
Example to get two leading zeros before the number with a range:
->setColumnFormat(array(
'A2:K2' => '0000'
))
#Auto filter
Setting filters on the heading
->setAutoFilter()
#Setting and styling borders
To style and set all borders use:
->setAllBorder('thick')
To style the border of a range
->setBorder('A1:F10','thick')
You can use all the PHP Excel border styles.
#Config
Optional settings can be found in the config file. Use the artisan publish command to publish the config file to your project.
php artisan config:publish maatwebsite/excel
#v1.0.0 TODO
- Unit testing
- Cell caching
#License
This package is licensed under LGPL. You are free to use it in personal and non-commercial projects. The code can be forked and modified, but original copyright author should always be included!