laravel的dcat扩展:xlswriter导出,自定义合并数据单元格,自定义样式、列宽

简介#

dcat 扩展:xlswriter 导出

之前用了 laravel-excel 做数据导出,很耗内存速度也慢,数据量大的时候内存占用容易达到 php 上限,或者响应超时,换成 xlswriter 这个扩展来做。

由于直接导出的表格不太美观,经常需要进行合并单元格和自定义表格样式等操作,我对此进行了一些封装,使用更加方便直观。

本扩展是 laravel-xlswriter-export 的 dcat 版本,使用文档直接看 laravel-xlswriter-export 的 readme 即可,此处只介绍不同点。

安装#

首先按文档把 xlswriter 扩展安装上

xlswriter-docs.viest.me/

在 phpinfo 中确认安装成功后,进行下一步

composer require aoding9/dcat-xlswriter-export

国内 composer 镜像如果安装失败,请设置官方源

composer config -g repo.packagist composer https://packagist.org

官方源下载慢,国内镜像偶尔出问题可能导致安装失败,也可以把以下代码添加到 composer.json,直接从 github 安装

如果无法访问 github, 可以将 url 改为 gitee:https://gitee.com/aoding9/dcat-xlswriter-export

{
  "repositories": [
    {
      "type": "vcs",
      "url": "https://github.com/aoding9/dcat-xlswriter-export"
    }
  ]
}

使用#

1. 定义导出类#

和 laravel-xlswriter-export 相同,不同点在于,不传参数将使用 dcat 中 grid 的查询构造器作为数据源,另外由于 make 方法与 dcat 不兼容,只能使用 new 的方式。

2、在控制器中使用#

在 grid 方法中使用 $grid->export(new UserExport()); 即可

由于构造函数传参为空,数据源为 other 类型,走 buildDataFromOther 获取 grid 数据,如有特殊需要,可以重写该方法修改获取到的数据

//use xxx

protected function grid() {
    return Grid::make(new User(), function(Grid $grid) {
         $grid->export(new UserExport());
        //$grid->export(new UserMergeExport());
    });
}

3、通过 swoole 使用#

由于 swoole 中不能调用 exit() 方法,需要在控制器中直接 return 下载响应

为此,需要在导出类中将 $useSwoole 属性设为 true, 然后在 dcat 控制器中引入 HandleExportIfUseSwoole,这个 trait 将重写 index 方法,以正确地触发下载

// UserExport中添加
public $useSwoole = true;

// UserController中添加
use Aoding9\Dcat\Xlswriter\Export\HandleExportIfUseSwoole;

版本更新#

  • v1.2.2 (2023-9-16)
    • download 时调用 $this->useSwoole() 判断是否使用了 swoole,如果使用了,将返回下载响应,代替默认的 exit ()
    • 新增 HandleExportIfUseSwoole,用于 swoole 访问 dcat 时,重写控制器的 index 以返回下载响应
本作品采用《CC 协议》,转载必须注明作者和本文链接
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
讨论数量: 4

虽然还没用上,但是先点一个赞!

1年前 评论

有没有导入的呢?速度怎样

1年前 评论
DogLoML (楼主) 1年前
DogLoML (楼主) 1年前