最简单的laravel不使用任何扩展导出csv

php导出csv是非常常用的操作,网上也有灰常多的扩展。如果只是单纯的导出csv数据,完全没有必要去用扩展。现在做项目,都是代码能少就少,扩展能不用就不用。好了,不废话了,开干!

直接搞一个方法,能够在各种地方调用

php 复制代码
/**
 * 导出CSV
 * $data    导出的数据信息
 * $header  导出的表头信息
 * $field   导出的字段信息
 * $file    导出的文件名
 */
public function csv($data, $header, $field, $file)
{
    // 临时文件目录
    $directory = storage_path('app/temp');
    // 判断临时文件目录是否存在
    if (!File::isDirectory($directory)) {
        // 创建一个临时文件目录
        File::makeDirectory($directory, 0755, true);
    }
    // 临时文件名称
    $filename = $file . date('YmdHis') . '.csv';
    // 临时文件完整路径
    $path = $directory . '/' . $filename;
    // 打开文件进行写入
    $fileCsv = fopen($path, 'w');
    // 写入头部
    fputcsv($fileCsv, $header);
    // 循环所有的写入数据
    foreach ($data as $row) {
        // 获取所有的数据的key
        $keys = array_keys($row);
        // 追加数据空数组
        $addRow = [];
        // 循环追加的所有字段
        foreach ($field as $k) {
            // 判断追加的字段键是都存在
            if (in_array($k, $keys)) {
                // 追加到数据空数组
                $addRow[] = $row[$k];
            } else {
                $this->error('字段' . $k . '不存在,请联系开发人员');
            }

        }
        // 追加到文件
        fputcsv($fileCsv, $addRow);
    }
    // 关闭文件
    fclose($fileCsv);
    // 将临时文件发送为下载响应
    return response()->download($path, $filename)->deleteFileAfterSend();
}

假设导出会员信息

php 复制代码
// 通过模型查询到用户数据
$data = \App\Models\Member::orderBy("id", "desc")->get()->toArray();
// 设置导出的表头(也就是第一行)
$header = ['ID', 'UID', '用户昵称', '用户手机', '累计消费', '注册时间'];
// 设置导出的字段
$field = ['id', 'uid', 'nike_name', 'phone', 'consume', 'created_at'];
// 调用导出
return $this->csv($data, $header, $field, 'member_');

每一行都有注释了,自行扩充,这是我自己一直用很简单的导出方式,希望大家阔以用得到

相关推荐
取码网16 分钟前
帝国CMS作文网题目文学文章wap+pc自适应响应式模板PHP网站源码
php
arron88991 小时前
RK3588 Ubuntu 22.04 静态 IP 真实配置文件位置 + 最稳修改方法
tcp/ip·ubuntu·php
温天仁7 小时前
西门子PLC编程实践教程:工控工程案例学习
开发语言·学习·自动化·php
小草cys10 小时前
review202604032342
开发语言·php
桌面运维家11 小时前
交换机环路排查:STP配置实战与网络故障精确定位
开发语言·php
广州灵眸科技有限公司11 小时前
瑞芯微(EASY EAI)RV1126B 人脸98关键点算法识别
开发语言·科技·嵌入式硬件·物联网·算法·php
Figo_Cheung11 小时前
赛博疯态(Cyber-Madness)研究报告——基于人机交互中的情感共鸣、递归指涉与拟人化投射现象分析
开发语言·php·人机交互
亚马逊云开发者11 小时前
用 Serverless 搭 IoT 设备异常检测:Lambda + Step Functions + DynamoDB 分钟级告警实战
物联网·serverless·php
TO_WebNow12 小时前
tp5部署宝塔遇到的问题
android·ide·php·android studio
Xudde.12 小时前
班级作业笔记报告0x07
笔记·学习·安全·web安全·php