2017 © Pedro PelĂĄez
 

library laravel-excel

This package provides a way to export an Eloquent collection as an excel file and to import a Excel file as an Eloquent collection.

image

cyber-duck/laravel-excel

This package provides a way to export an Eloquent collection as an excel file and to import a Excel file as an Eloquent collection.

  • Monday, September 11, 2017
  • by cyber-duck
  • Repository
  • 4 Watchers
  • 21 Stars
  • 9,760 Installations
  • PHP
  • 1 Dependents
  • 0 Suggesters
  • 12 Forks
  • 5 Open issues
  • 12 Versions
  • 18 % Grown

The README.md

Laravel Excel

Latest Stable Version Total Downloads License, (*1)

Exporting and importing Excel, CSV and OpenOffice stylesheets using Eloquent Collections and Query Builders in Laravel (5.* and 4.*).
It's based on box/spout., (*2)

Author: Simone Todaro
Contributors: Clément Blanco
Made with :heart: by Cyber-Duck Ltd, (*3)

Installation
Export Excel
Import Excel
Different formats, (*4)

Installation

Use composer to download the package:, (*5)

composer require cyber-duck/laravel-excel

Laravel 4.x

Register the service provider in config/app.php by adding this line to providers array., (*6)

'providers' => [
    Cyberduck\LaravelExcel\ExcelLegacyServiceProvider::class,
],

Laravel < 5.5

Register the service provider in config/app.php by adding this line to providers array., (*7)

'providers' => [
    Cyberduck\LaravelExcel\ExcelServiceProvider::class,
],

Laravel > 5.5

No need to register anything, since it used package auto discovery feature in Laravel 5.5., (*8)

Export Excel

Generate and download an excel file

Add, (*9)

use Exporter;

to your controller., (*10)

In your controler function, create a new excel file from an Eloquent collection., (*11)

$excel = Exporter::make('Excel');
$excel->load($yourCollection);
return $excel->stream($yourFileName);

The exporter class is fluent, so you can also write, (*12)

return Exporter::make('Excel')->load($yourCollection)->stream($yourFileName);

The exporter class supports Query builder objects as well, (*13)

$query = DB:table('table')->select('col1','col2');
$excel = Exporter::make('Excel');
$excel->loadQuery($query);
return $excel->stream($yourFileName);

If you deal with big tables, you can set the chunk size to minimise the memory usage, (*14)

$query = DB:table('table')->select('col1','col2');
$excel = Exporter::make('Excel');
$excel->loadQuery($query);
$excel->setChunk(1000);
return $excel->stream($yourFileName);

Generate and save an excel file

To save the excel file on the server, use the save method., (*15)

return $excel->save($yourFileNameWithPath);

Advanced usage

By default, every element of the Collection becomes a row and every unprotected field of the Model becomes a cell.
No headers row is printed., (*16)

To change this behaviour, create a class extending Cyberduck\LaravelExcel\Contract\SerialiserInterface, implement the methods getHeaderRow() and getData(Model $data) and set this class on the excel object usint setSerialiser()., (*17)

$serialiser = new CustomSerialiser();
$excel = Exporter::make('Excel');
$excel->load($collection);
$excel->setSerialiser($serialiser);
return $excel->stream($yourFileName);

getHeaderRow() must return an array of string where every element is a cell of the first row. To not print the header row, simply return a void array [].
getData(Model $data) must return an array of string, and every elements is a cell., (*18)

Example, (*19)

namespace App\Serialisers;

use Illuminate\Database\Eloquent\Model;
use Cyberduck\LaravelExcel\Contract\SerialiserInterface;

class ExampleSerialiser implements SerialiserInterface
{
    public function getData($data)
    {
        $row = [];

        $row[] = $data->field1;
        $row[] = $data->relationship->field2;

        return $row;
    }

    public function getHeaderRow()
    {
        return [
            'Field 1',
            'Field 2 (from a relationship)'
        ];
    }
}

then set the serialiser before saving the file the collection., (*20)

$collection = Exporter::make('Excel')->load($yourCollection)->setSerialiser(new ExampleSerialiser)->stream($yourFileName);

Import Excel

Add, (*21)

use Importer;

to your controller., (*22)

In your controler function, import an excel file., (*23)

$excel = Importer::make('Excel');
$excel->load($filepath);
$collection = $excel->getCollection();
//dd($collection)

The importer class is fluent, then you can also write, (*24)

return Importer::make('Excel')->load($filepath)->getCollection();

Advanced usage

By default, every row of the first sheet of the excel file becomes an array and the final result is wraped in a Collection (Illuminate\Support\Collection)., (*25)

To import a different sheet, use setSheet($sheet), (*26)

$excel = Importer::make('Excel');
$excel->load($filepath);
$excel->setSheet($sheetNumber);
$collection = $excel->getCollection();
//dd($collection)

To import each row in an Eloquent model, create a class extending Cyberduck\LaravelExcel\Contract\ParserInterface and implement the methods transform($row)., (*27)

Example, (*28)

namespace App\Parsers;

use App\Models\YourModel;
use Cyberduck\LaravelExcel\Contract\ParserInterface;

class ExampleParser implements ParserInterface
{
    public function transform($row, $header)
    {
        $model = new YourModel();
        $model->field1 = $row[0];
        $model->field2 = $row[1];
        // We can manunipulate the data before returning the object
        $model->field3 = new \Carbon($row[2]);
        return $model;
    }
}

then set the parser before creating the collection., (*29)

$collection = Importer::make('Excel')->load($filepath)->setParser(new ExampleParser)->getCollection();

Different formats

The package supports ODS and CSV files., (*30)

ODS

$exporter = Exporter::make('OpenOffice');
$importer = Importer::make('OpenOffice');

CSV

$exporter = Exporter::make('Csv');
$importer = Importer::make('Csv');

The Versions

11/09 2017

dev-master

9999999-dev

This package provides a way to export an Eloquent collection as an excel file and to import a Excel file as an Eloquent collection.

  Sources   Download

MIT

The Requires

 

The Development Requires

laravel eloquent excel export importer import exporter spout

27/08 2017

1.2.1

1.2.1.0

This package provides a way to export an Eloquent collection as an excel file and to import a Excel file as an Eloquent collection.

  Sources   Download

MIT

The Requires

 

The Development Requires

laravel eloquent excel export importer import exporter spout

02/08 2017

1.2.0

1.2.0.0

This package provides a way to export an Eloquent collection as an excel file and to import a Excel file as an Eloquent collection.

  Sources   Download

MIT

The Requires

 

The Development Requires

laravel eloquent excel export importer import exporter spout

01/07 2017

1.1.0

1.1.0.0

This package provides a way to export an Eloquent collection as an excel file and to import a Excel file as an Eloquent collection.

  Sources   Download

MIT

The Requires

 

The Development Requires

laravel eloquent excel export importer import exporter spout

03/10 2016

1.0.7

1.0.7.0

This package provides a way to export an Eloquent collection as an excel file and to import a Excel file as an Eloquent collection.

  Sources   Download

MIT

The Requires

 

laravel eloquent excel export importer import exporter spout

25/09 2016

1.0.6

1.0.6.0

This package provides a way to export an Eloquent collection as an excel file and to import a Excel file as an Eloquent collection.

  Sources   Download

MIT

The Requires

 

laravel excel export exporter

06/09 2016

1.0.5

1.0.5.0

This package provides a way to export an Eloquent collection as an excel file and to import a Excel file as an Eloquent collection.

  Sources   Download

MIT

The Requires

 

laravel excel export exporter

06/09 2016

1.0.4

1.0.4.0

This package provides a way to export an Eloquent collection as an excel file and to import a Excel file as an Eloquent collection.

  Sources   Download

MIT

The Requires

 

laravel excel export exporter

18/04 2016

v1.0.3

1.0.3.0

  Sources   Download

MIT

The Requires

 

laravel excel

16/04 2016

v1.0.2

1.0.2.0

  Sources   Download

MIT

The Requires

 

laravel excel

16/04 2016

v1.0.1

1.0.1.0

  Sources   Download

MIT

The Requires

 

laravel excel

29/02 2016

v1.0.0

1.0.0.0

  Sources   Download

MIT

The Requires

 

laravel excel