首页 > 其他 > 详细

# Laravel Excel安装及最简单使用

时间:2019-06-02 15:06:16      阅读:92      评论:0      收藏:0      [点我收藏+]

官网:https://docs.laravel-excel.com/

1、安装

1.1、安装要求:

? PHP: ^7.0

? Laravel: ^5.5

? PhpSpreadsheet: ^1.6

? PHP扩展已php_zip启用

? PHP扩展已php_xml启用

? PHP扩展已php_gd2启用

1.2、安装

//安装
composer require maatwebsite/excel

在laravel项目config/app.php中

//providers元素添加
Maatwebsite\Excel\ExcelServiceProvider::class,

//aliases元素添加
'Excel' => Maatwebsite\Excel\Facades\Excel::class,

发布配置

php artisan vendor:publish --provider="Maatwebsite\Excel\ExcelServiceProvider"
//将自动建立一个新配置文件config/excel.php

2、导出

2.1、新建导出类

php artisan make:export TestExport
//执行后会在新建app/Export/TestExport.php文件

2.2、导出类实现FromArray接口

新建的export,默认实现的接口是FromCollection,更改为FromArray,实现array方法

FromCollection以后有机会再讲

一般导出会传个id,到数据库查数据,例子传了个id但没到数据库查询

use Maatwebsite\Excel\Concerns\FromArray;

class TestExport implements FromArray
{
    private $id;
    public function __construct($id)
    {
        $this->id = $id;
    }
  
    public function array(): array
    {
        $data = [[$this->id,$this->id,$this->id],[1,2,3],[4,5,6],[7,8,9]];//测试数据
        return $data;
    }
}

2.3、控制器中导出

use Maatwebsite\Excel\Facades\Excel;

class TestController extends Controller
{
    public function export($id)
    {
        return Excel::download(new TestExport($id),'test.xlsx');
    }
}

2.4、定义路由

Route::get('/test/export/id/{id}', 'TestController@export');

2.5、结果

访问: xx.com/test/export/id/1 即可导出
技术分享图片

3、导入

3.1、新建导入类

php artisan make:import TestImport
//执行后会在新建app/Export/TestExport.php文件

3.2、导入类实现FromArray接口

新建的import,默认实现的接口是ToCollection,更改为ToArray,实现array方法

ToCollection以后有机会再讲

use Maatwebsite\Excel\Concerns\ToArray;

class TestImport implements ToArray
{
    public function array(array $array)
    {
        //处理导入数据$array
        //...
        return $array;
    }
}

3.3、控制器导入

将上面导出的test.xlsx,放到/public/file目录下

public function import()
{
     $array = Excel::toArray(new TestImport, public_path('/file/test.xlsx'));
     dd($array);//简单的打印一下
}

3.4、定义路由

Route::get('/test/import', 'TestController@import');

3.5、结果

访问: xx.com/test/import 即可导出,

这里导入非手动选择,而是指定了文件路径/public/file/test.xlsx文件

结果:
技术分享图片

感受:

? laravel excel3.1挺好用的,但光看文档不太能够使用,国内的文档大多还是老版本的。官方文档连最简单的导入导出数组,都没怎么涉及到,也可能是我对laravel不够熟悉吧。

# Laravel Excel安装及最简单使用

原文:https://www.cnblogs.com/mg007/p/10962668.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!