iklan

✔ Laravel 5 Tutorial : Laravel Export Data To An Excel Spreadsheet Or Pdf Files

Laravel 5.3 tutorial - How to export data from database into an Excel Spreadsheet or PDF Files in laravel 5.3?

Laravel Excel brings the power of PHPOffice's PHPExcel to Laravel 5 with a touch of the Laravel Magic. It includes features like: importing Excel and CSV to collections, exporting models, array's and views to Excel, importing batches of files and importing a file by a config file.

At the previews lessons, we have learn how to export data to PDF, so please read How to Export to PDF using Dompdf Library with Example.

Video Tutorial Laravel Export Data to an Excel Spreadsheet or PDF Files



Full Source Code

Installing Laravel-Ecel

Require this package in your composer.json and update composer. This will d0wnl0ad the package and PHPExcel of PHPOffice.
 "maatwebsite/excel": " 2.1.0" 

After updating composer, add the ServiceProvider to the providers array in config/app.php
 Maatwebsite\Excel\ExcelServiceProvider::class, 

You can use the facade for shorter code. Add this to your aliases:
 'Excel' => Maatwebsite\Excel\Facades\Excel::class, 

Publish the config settings in Laravel 5
 php artisan vendor:publish --provider="Maatwebsite\Excel\ExcelServiceProvider" 

Controller (PDFController.php)

<?php  namespace App\Http\Controllers; use Illuminate\Http\Request; use PDF; // pdf namespace use Excel; // Excel namespace  use App\datatoPDF; class PDFController extends Controller {     // show all data     public function index(Request $req)     {       // show all data to index       $blogs = datatoPDF::all();       view()->share('blogs',$blogs);       // if request has pdf       if($req->has('d0wnl0adpdf')){         $pdf = PDF::loadView('pdf')->setPaper('a4', 'landscape');         return $pdf->d0wnl0ad('pdf');       }       // if request has excel       if($req->has('d0wnl0adexcel')){         Excel::create('users', function($excel) use ($blogs) {           $excel->sheet('Sheet 1', function($sheet) use ($blogs) {             $sheet->fromArray($blogs);           });         })->export('xls');       }       // return index page       return view('index');     } } 

Models (datatoPDF.php)

<?php  namespace App;  use Illuminate\Database\Eloquent\Model;  class datatoPDF extends Model {     protected $table = 'users'; }

Routes (Web.php)

Route::get('/',array('as'=>'htmltopdf','uses'=>'PDFController@index')); 

Views (index.blade.php)

 <!DOCTYPE html> <html lang="en">   <head>     <meta charset="utf-8">     <meta http-equiv="X-UA-Compatible" content="IE=edge">     <meta name="viewport" content="width=device-width, initial-scale=1">     <title>All Users Data</title>      <!-- Bootstrap -->     <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css">     <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.4.0/css/font-awesome.min.css">      <!-- HTML5 Shim and Respond.js IE8 support of HTML5 elements and media queries -->     <!-- WARNING: Respond.js doesn't work if you view the page via file:// -->     <!--[if lt IE 9]>       <script src="https://oss.maxcdn.com/libs/html5shiv/3.7.2/html5shiv.js"></script>       <script src="https://oss.maxcdn.com/libs/respond.js/1.4.2/respond.min.js"></script>     <![endif]-->   </head>   <body>      <div class="container">       <h2>All Users Data</h2>       <div class="btn-group">         <button class="btn btn-primary btn-xs dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">           Export All Data <span class="caret"></span>         </button>         <ul class="dropdown-menu">           <li><a href="{{ route('htmltopdf',['d0wnl0adpdf'=>'pdf']) }}">Export to PDF</a></li>           <li><a href="{{ route('htmltopdf',['d0wnl0adexcel'=>'excel']) }}">Export to Excel</a></li>         </ul>       </div>       <table class="table table-striped">         <thead>           <tr>             <th>ID</th>             <th>Name</th>             <th>Email</th>             <th>Password</th>             <th>Created At</th>             <th><button class="btn btn-success btn-xs">Add New Supplier</button></th>           </tr>         </thead>         <tbody>           @foreach($blogs as $blog)             <tr>               <td>{{ $blog->id }}</td>               <td>{{ $blog->name }}</td>               <td>{{ $blog->email }}</td>               <td>{{ $blog->password }}</td>               <td>{{ $blog->created_at }}</td>               <td>                 <button class="btn btn-warning btn-xs btn-detail">                   <span class="glyphicon glyphicon-edit"></span>                 </button>                 <button class="btn btn-danger btn-xs btn-delete">                   <span class="glyphicon glyphicon-trash"></span>                 </button>               </td>             </tr>           @endforeach         </tbody>       </table>     </div>     <!-- jQuery (necessary for Bootstrap's JavaScript plugins) -->     <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script>     <!-- Include all compiled plugins (below), or include individual files as needed -->     <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>   </body> </html> 

Download Full source code Laravel Export Data to an Excel Spreadsheet or PDF Files

If you found Sector Code helpful, amazing and awesome, please like, share and join us in youtube. See you next lessons...
Sumber http://scqq.blogspot.com

Berlangganan update artikel terbaru via email:

0 Response to "✔ Laravel 5 Tutorial : Laravel Export Data To An Excel Spreadsheet Or Pdf Files"

Posting Komentar

Iklan Atas Artikel

Iklan Tengah Artikel 1

Iklan Tengah Artikel 2

Iklan Bawah Artikel