Maison  >  Article  >  développement back-end  >  Utiliser LaravelExcel pour implémenter la fonction d'exportation de fichiers dans Laravel5

Utiliser LaravelExcel pour implémenter la fonction d'exportation de fichiers dans Laravel5

不言
不言original
2018-05-08 10:51:524938parcourir

Cet article présente principalement la fonction d'exportation de fichiers utilisant LaravelExcel dans Laravel5. Il a maintenant une certaine valeur de référence. Maintenant, je le partage avec tout le monde. Les amis dans le besoin peuvent s'y référer

Utiliser Laravel/Excel dans Laravel5 pour l'implémenter. it. Fonction d'exportation de fichiers Excel/CSV

1. Installation
Ici, j'ai installé la version 2.1.0 de maatwebsite/excel

composer require "maatwebsite/excel:~2.1.0"

Paramètres après l'installation
Dans la configuration Enregistrez le fournisseur de services au tableau des fournisseurs dans /app.php :

Maatwebsite\Excel\ExcelServiceProvider::class,

Enregistrez également la façade dans le tableau des alias dans config/app.php :

'Excel' => Maatwebsite\Excel\Facades\Excel::class,

Si vous souhaitez utiliser Laravel Pour des configurations plus personnalisées dans Excel, exécutez les commandes Artisan suivantes :

php artisan vendor:publish --provider="Maatwebsite\Excel\ExcelServiceProvider"

2. Exporter les données
Ajouter un routage

// excel exportRoute::get('/monitor/export','Admin\ExcelController@export')->name('monitor.export');

Créer un contrôleur

php artisan make:controller Admin/ExcelController

Ajoutez du code dans le contrôle

<?php
namespace App\Http\Controllers\Admin;use Illuminate\Http\Request;
use App\Http\Controllers\Controller;use Excel;use App\Models\Monitor;
use App\Exports\CunliangExport;class ExcelController extends Controller
{
    public function export()
    {
        //return Excel::download(new CunliangExport, &#39;invoices.xlsx&#39;);
        $data = Monitor::get()->toArray();        
        return Excel::create(&#39;数据更新&#39;, function($excel) use ($data) {
            $excel->sheet(&#39;数据更新&#39;, function($sheet) use ($data)
            {
                $sheet->cell(&#39;A1&#39;, function($cell) {$cell->setValue(&#39;update_date&#39;);   });                
                $sheet->cell(&#39;B1&#39;, function($cell) {$cell->setValue(&#39;file_type&#39;);   });                
                $sheet->cell(&#39;C1&#39;, function($cell) {$cell->setValue(&#39;file_num&#39;);   });                
                $sheet->cell(&#39;D1&#39;, function($cell) {$cell->setValue(&#39;space_size&#39;);   });                
                $sheet->cell(&#39;E1&#39;, function($cell) {$cell->setValue(&#39;exec_time&#39;);   });                
                $sheet->cell(&#39;F1&#39;, function($cell) {$cell->setValue(&#39;created_at&#39;);   });                
                if (!empty($data)) {                    
                foreach ($data as $key => $value) {                        
                $i= $key+2;                        
                $sheet->cell(&#39;A&#39;.$i, $value[&#39;update_date&#39;]);                        
                $sheet->cell(&#39;B&#39;.$i, $value[&#39;file_type&#39;]);                        
                $sheet->cell(&#39;C&#39;.$i, $value[&#39;file_num&#39;]);                        
                $sheet->cell(&#39;D&#39;.$i, $value[&#39;space_size&#39;]);                        
                $sheet->cell(&#39;E&#39;.$i, $value[&#39;exec_time&#39;]);                        
                $sheet->cell(&#39;F&#39;.$i, $value[&#39;created_at&#39;]);
                    }
                }
            });
        })->download(&#39;xlsx&#39;);
    }
}

Ajoutez le code suivant dans le fichier modèle de lame

.
.
.<p class="box-header">
    <a class="btn btn-success" href="{{route(&#39;monitor.export&#39;)}}">导出</a></p>.
.
.

Vous pouvez le modifier en fonction de vos besoins.

Recommandations associées :

Laravel5 implémente la fonction de correspondance floue

Rapport d'erreurs sur la nouvelle fonctionnalité Laravel5.5

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Article précédent:Exemple simple RedisArticle suivant:Exemple simple Redis