1.Laravel Excel

Laravel Excel 是一款基于PHPExcel开发的Laravel框架专用的Excel/CSV 文件导入导出功能的扩展包,用起来的非常方便。
它的Github地址是:https://github.com/Maatwebsite/Laravel-Excel
当然了,你也可以使用PHPExcel,但是请注意,PHPExcel官方团队已经停止维护了,现在官方团队开发维护的是它的升级版PHPExcel扩展包,叫做:PhpSpreadsheet
我们今天主要介绍(因为我前天项目中用到了导出,最后选择了Laravel Exxcel☺):Laravel Excel

安装

1). 使用 Composer 安装该扩展包  php7.1以上用3.1.0版本:

    1. composer require "maatwebsite/excel:~3.1.0"

2).
安装完成后,修改 config/app.php 在 providers 数组内追加如下内容

[html] view plain copy
  1. 'providers' => [
  2. ...
  3. Maatwebsite\Excel\ExcelServiceProvider::class,
  4. ],

3).
同时在 aliases 数组内追加如下内容:

[html] view plain copy
  1. 'aliases' => [
  2. ...
  3. 'Excel' => Maatwebsite\Excel\Facades\Excel::class,
  4. ]

4).
接下来运行以下命令生成此扩展包的配置文件 config/excel.php:

[html] view plain copy

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

5.创建导出类

php artisan make:export ExcelExport

  1. <?php
  2.  
  3. namespace App\Exports;
  4.  
  5. use Maatwebsite\Excel\Concerns\FromCollection;
  6. use Maatwebsite\Excel\Concerns\Exportable;
  7. use Maatwebsite\Excel\Concerns\WithHeadings;
  8. class ExcelExport implements FromCollection, WithHeadings
  9. {
  10. use Exportable;
  11.  
  12. private $data;
  13. private $headings;
  14.  
  15. //数据注入
  16. public function __construct($data, $headings)
  17. {
  18. $this->data = $data;
  19. $this->headings = $headings;
  20. }
  21.  
  22. //实现FromCollection接口
  23. public function collection()
  24. {
  25. return collect($this->data);
  26. }
  27.  
  28. //实现WithHeadings接口
  29. public function headings(): array
  30. {
  31. return $this->headings;
  32. }
  33. }

6.控制器里

  1. public function export(){
  2. $data = [
  3. [
  4. 'name' => 'cheng',
  5. 'email' => 'cheng222'
  6. ],
  7. [
  8. 'name' => 'cheng',
  9. 'email' => 'cheng111'
  10. ],
  11. ];
  12.  
  13. $headings = [
  14. 'name',
  15. 'email'
  16. ];
  17. return Excel::download(new ExcelExport($data, $headings), 'users.csv');
  18.  
  19. }

导入文件

1.创建导入类

php artisan make:import ExcelImport

这里向和我一样不明白的小白说下,关于导入导出excel 文档里主要设计到三种 : 模型 model  , 集合 collection , 数组 Array

此外还有 implements ToArray 和 implements ToCollection 两个方法,

  1. <?php
  2.  
  3. namespace App\Imports;
  4.  
  5. use App\User;
  6. use Illuminate\Support\Facades\Hash;
  7. use Maatwebsite\Excel\Concerns\ToModel;
  8.  
  9. class UsersImport implements ToModel
  10. {
  11. /**
  12. * @param array $row
  13. *
  14. * @return User|null
  15. */
  16. public function model(array $row)
  17. {
  18. return new User([
  19. 'name' => $row[],
  20. 'email' => $row[],
  21. 'password' => Hash::make($row[]),
  22. ]);
  23. }
  24. }
  1. <?php
  2.  
  3. namespace App\Imports;
  4.  
  5. use Illuminate\Support\Collection;
  6. use Maatwebsite\Excel\Concerns\ToArray;
  7.  
  8. class UsersImport implements ToArray
  9. {
  10. public function Array(Array $tables)
  11. {
  12. return $tables;
  13. }
  14.  
  15. }

控制器的两种用法

  1. $array = Excel::toArray(new UsersImport, 'users.xlsx');
  2.  
  3. $collection = Excel::toCollection(new UsersImport, 'users.xlsx');

如何在 Laravel 项目中处理 Excel 文件的更多相关文章

  1. [Laravel-Swagger]如何在 Laravel 项目中使用 Swagger

    如何在 Laravel 项目中使用 Swagger http://swagger.io/getting-started/ 安装依赖 swagger-php composer require zirco ...

  2. C#项目中操作Excel文件——使用NPOI库

    转载自:http://blog.csdn.net/dcrmg/article/details/52356236# 感谢-牧野- 实际C#项目中经常会涉及到需要对本地Excel文件进行操作,特别是一些包 ...

  3. Vue项目中导入excel文件读取成js数组

    1. 安装组件 cnpm install xlsx --save 2. 代码 <template> <span> <input class="input-fil ...

  4. vue项目中导出Excel文件功能的前端代码实现

    在项目中遇到了两种不同情况, 1.get请求导出文件,实现起来相对简单 // 导出数据 exportData() { window.location.href = `/oes-content-mana ...

  5. #iPhone6与iPhone6Plus适配#如何在Xcode 6中创建 PCH 文件

    本文永久链接http://www.cnblogs.com/ChenYilong/p/4008086.html   新建文件 ⌘+N选择 iOS/Mac -> Other -> PCH Fi ...

  6. 如何在cocos2d项目中enable ARC

    如何在cocos2d项目中enable ARC 基本思想就是不支持ARC的代码用和支持ARC的分开,通过xcode中设置编译选项,让支持和不支持ARC的代码共存. cocos2d是ios app开发中 ...

  7. 如何在NodeJS项目中优雅的使用ES6

    如何在NodeJS项目中优雅的使用ES6 NodeJs最近的版本都开始支持ES6(ES2015)的新特性了,设置已经支持了async/await这样的更高级的特性.只是在使用的时候需要在node后面加 ...

  8. 如何在VUE项目中添加ESLint

    如何在VUE项目中添加ESLint 1. 首先在项目的根目录下 新建 .eslintrc.js文件,其配置规则可以如下:(自己小整理了一份),所有的代码如下: // https://eslint.or ...

  9. 如何在mvc项目中使用apiController

    文章地址:How do you route from an MVC project to an MVC ApiController in another project? 文章地址:How to Us ...

随机推荐

  1. 2019年9月(System.Data.OracleClient 需要 Oracle 客户端软件 version 8.1.7 或更高版本。)问题解决记录

    System.Data.OracleClient 需要 Oracle 客户端软件 version 8.1.7 或更高版本. 在百度上寻找了很久,都说是权限的问题,可是更改过后一点效果也没有. 实际上真 ...

  2. 【LOJ】#3096. 「SNOI2019」数论

    LOJ#3096. 「SNOI2019」数论 如果\(P > Q\)我们把\(P\)和\(Q\)换一下,现在默认\(P < Q\) 这个时候每个合法的\(a_i\)都可以直接落到\(Q\) ...

  3. javaweb项目的全局监听配置

    在项目中有时候会遇到全局监听的需求,而全局性的监听该如何配置,代码如下: package com.demo.listener; import javax.servlet.ServletContextE ...

  4. HDU 3642 求体积交集

    Get The Treasury 题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=3642 Problem Description Jack knows ...

  5. python基础(十三)--os和sys模块

    os模块 os.getpwd():获取当前工作目录(windows下没有) os.listdir(path):列出目录下的文件 os.remove(path):删出文件 (不能是目录,即文件夹) os ...

  6. Asp.net core 学习笔记 QR code and Barcode

    QR code 和 Barcode 经常会使用到. Java 阵营有著名的 zxing https://github.com/zxing/zxing .Net 有对接它的 port https://g ...

  7. 复习二叉数 pat l2-006 数的遍历

    L2-006. 树的遍历   给定一棵二叉树的后序遍历和中序遍历,请你输出其层序遍历的序列.这里假设键值都是互不相等的正整数. 输入格式: 输入第一行给出一个正整数N(<=30),是二叉树中结点 ...

  8. Mysql定时备份[Windows]

    基于mysql5.6.39版本 一.备份脚本 1.windows环境创建批处理文件 @echo off rem ******MySQL backup start****** set mysqlHome ...

  9. STM32工程模版

    STM32工程模版,看过来 ST库源码去官方下载 创建工程目录 doc:存放说明文档 lib:存放库文件 listing:存放编译产生的中间文件 output:存放生成的文件 project:存放工程 ...

  10. Saladict 沙拉查词

    Saladict 沙拉查词 鼠标中键呼出 整合了有道翻译.百度翻译.必应翻译.腾讯翻译君. Google 翻译和彩云小译等,自动发音,可配置词典. 说明文档:https://github.com/cr ...