侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

dcatadmin 添加导出csv文件功能

Laravel  /  管理员 发布于 2年前   1016

dcat-admin中纯PHP实现导出csv文件功能流程步骤


创建工具类

在app/Admin/Extensions/Grid/Tools下,可自行创建。

use Dcat\Admin\Grid\Tools\AbstractTool;
class UsersExporter extends AbstractTool
{
    // 工具按钮标题
    protected $title = '<i class="feather icon-download"></i> 导出';
    // 工具按钮样式。
    protected $style = 'btn btn-success grid-refresh btn-mini users-exporter';
    protected function script(): string
    {
        // 获取grid所有筛选参数
        $request = request()->all();
        // 自动拼接生成URL参数字符串
        $query = http_build_query($request, '&');
        // 工具按钮点击事件
        return <<<JS
$('.users-exporter').off('click').on('click', function() {
    Dcat.confirm('数据过多时,请耐心等待', '确认导出?', function () {
      window.location.href = '/admin/ajax/export/users?$query';
    });
});
JS;
    }
}


添加路由

在app/Admin/routes.php文件种添加路由。

use App\Admin\Controllers\Ajax\ExportController;
Route::group([
    'prefix'     => config('admin.route.prefix'),
    'namespace'  => config('admin.route.namespace'),
    'middleware' => config('admin.route.middleware'),
], function (Router $router) {
    Route::get('ajax/export/users', [ExportController::class, 'users']);
});


创建ExportController导出类


use App\Http\Controllers\Controller;
use App\Models\Users;
use Illuminate\Support\Str;
set_time_limit(0);
ini_set('memory_limit', '5000M');
if (ob_get_contents()) ob_end_clean();
class ExportController extends Controller
{
    public static array $exportTitles = [
        'name'          => '账号',
        'username'      => '昵称',
        'email'         => '邮箱',
        'mobile'        => '手机号',
        'real_name'     => '真实姓名',
        'identity_card' => '身份证',
        'area'          => '身份证地址',
        'sex'           => '年龄',
        'age'           => '年龄',
        'zodiac'        => '生肖',
        'status'        => '状态',
        'login_ip'      => '登陆ip',
        'login_at'      => '登陆时间',
        'created_at'    => '创建时间',
        'updated_at'    => '更新时间'
    ];
   
    public function users()
    {
        $fileName = '用户列表-' . (date('Ymd-His') . '-' . Str::random(6)) . '.csv';
        $columns = array_keys(self::$exportTitles);
        $query = Users::query()->select($columns)->where(function ($query) {
            if (request('name'))
                $query->where('name', request('name'));
            if (request('mobile'))
                $query->where('mobile', request('mobile'));
            if (request('identity_card'))
                $query->where('identity_card', request('identity_card'));
            if (request('sex'))
                $query->where('sex', request('sex'));
            if (request('status'))
                $query->where('status', request('status'));
        });
        if (isset($this->request['_sort']))
            $query = $query->orderBy($this->request['_sort']['column'], $this->request['_sort']['type']);
        else
            $query = $query->orderByDesc('id');
        // 设置文件头
        header('content-Type:application/vnd.ms-excel;charset=utf-8');
        header("Content-Disposition:attachment;filename=$fileName");
        header('Cache-Control:max-age=0');
        // 打开PHP文件句柄,php://output 表示直接输出到浏览器
        $fp = fopen('php://output', 'a');
        // 计数器
        $num = 0;
        // 每次获取1000条数据写入
        $chunkSize = 1000;
        // 切片次数
        $chunkNum = ceil($query->count() / $chunkSize);
        // 输出Excel列名信息
        $headings = [];
        foreach (self::$exportTitles as $i => $v) {
            //将utf-8编码转为gbk。理由是:Excel 以 ANSI 格式打开,不会做编码识别。如果直接用 Excel 打开 UTF-8 编码的 CSV 文件会导致汉字部分出现乱码。
            $headings[$i] = iconv("UTF-8", "GBK//IGNORE", $v);
            unset($v);
        }
        // 写到第一行
        fputcsv($fp, $headings);
        for ($i = 0; $i < $chunkNum; $i++) {
            $lists = $query->forPage(($i + 1), $chunkSize)->get();
            foreach ($lists as $value) {
                $data = [];
                foreach ($columns as $v) {
                    $num++;
                    // 刷新一下输出buffer,防止由于数据过多造成问题
                    if ($chunkSize == $num) {
                        ob_flush(); //清除内存
                        flush();
                        $num = 0;
                    }
                    $string = $value[$v];
                    // 处理科学计数,用不上可以删除
                    if (in_array($v, ['name', 'identity_card']))
                        $string = ("\t" . $value[$v]);
                    /**
                     * 处理状态显示,用不上可以删除
                     *
                     * 以下是模型代码示例,也可自行处理
                     *
                     * protected $appends = ['sex_desc'];
                     *
                     * public function getSexDescAttribute(): string
                     * {
                     *      return Arr::get([1=>'男',2=>'女'], $this->attributes['sex'], '男');
                     * }
                     *
                     * 字段
                     * $this->attributes['sex']
                     * #
                     * $this->sex
                     */
                    if (in_array($v, ['sex', 'status']))
                        $string = $value["{$v}_desc"];
                    // 转为gbk的时候可能会遇到特殊字符‘-’之类的会报错,加ignore表示这个特殊字符直接忽略不做转换。
                    $data[] = iconv("UTF-8", "GBK//IGNORE", $string);;
                    unset($v);
                }
                fputcsv($fp, $data);
                unset($value, $data);
            }
            unset($lists);
        }
        ob_flush(); // 清除内存
        fclose($fp);  //关闭句柄
    }
}


调用使用

use App\Admin\Extensions\Grid\Tools\UsersExporter;
$grid->tools(function (Grid\Tools $tools) {
    $tools->append(new UsersExporter());
});

完


  • 上一条:
    Laravel 9.26版本发布
    下一条:
    项目过期日志定时清理功能实现方案:Shermie-Log-Manager + crontab
  • 昵称:

    邮箱:

    1条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Laravel 11.15版本发布 - Eloquent Builder中添加的泛型(0个评论)
    • Laravel 11.14版本发布 - 新的字符串助手和ServeCommand改进(0个评论)
    • Laravel 11.12版本发布 - Artisan的`make`命令自动剪切`.php `扩展(0个评论)
    • Laravel的轻量型购物车扩展包:binafy/laravel-cart(0个评论)
    • Laravel 11.11版本发布 - 查看模型中的第三方关系:show(0个评论)
    • 近期文章
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-07
    • 2017-08
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-08
    • 2020-09
    • 2020-10
    • 2020-11
    • 2021-01
    • 2021-02
    • 2021-03
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-03
    • 2022-04
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    • 2024-05
    • 2024-06
    • 2024-07
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客