Skip to content

An eloquent way of importing and exporting Excel and CSV files for Laravel with the power of PHPExcel

License

Notifications You must be signed in to change notification settings

pankitgami/Laravel-Excel

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Laravel 4 Wrapper for PHPExcel v0.4.0 - DEV

Latest Stable Version Total Downloads Latest Unstable Version License Monthly Downloads Daily Downloads

#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')

View styling

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!

About

An eloquent way of importing and exporting Excel and CSV files for Laravel with the power of PHPExcel

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • PHP 100.0%