Maison > développement back-end > tutoriel php > 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

不言
Libérer: 2023-03-25 15:50:01
original
5004 Les gens l'ont consulté

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"
Copier après la connexion

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,
Copier après la connexion

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

'Excel' => Maatwebsite\Excel\Facades\Excel::class,
Copier après la connexion

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"
Copier après la connexion

2. Exporter les données
Ajouter un routage

// excel exportRoute::get('/monitor/export','Admin\ExcelController@export')->name('monitor.export');
Copier après la connexion

Créer un contrôleur

php artisan make:controller Admin/ExcelController
Copier après la connexion

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;);
    }
}
Copier après la connexion

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>.
.
.
Copier après la connexion

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!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal