IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> PHP知识库 -> php 实现excel打包下载 -> 正文阅读

[PHP知识库]php 实现excel打包下载

场景说明:
举例说明:一个表单下面有多个提交的留言,导出这些留言,并且一个表单是一个excel

生成zip压缩包

$msgList是数据,这里我将要导出的列表、列标题、名称都放在了一个变量中传递过来了,具体的数据结构如下

$msgList = [
	[
		"formTitle" => "我将作为压缩包中excel的名字",
		"fields" => [
			"name" => "姓名",
			"phone" => "手机号"
		],
		"msgList" => [
			[
				"name" => "小明",
				"phone" => "18888888888",
			],
			[
				"name" => "小红",
				"phone" => "19999999999",
			]
		]
	]
]

上面的$msgList只是为了帮助理解下面方法的用法,结构不重要,重要的是实现的原理:

  1. 先将每个表单的数据生成各自的excel,临时存放在某个文件夹里面,这个文件夹必须要有写入的权限。我这里调用了exportSingleExcel,这一步就像是常规生成excel,只是没有将其输出到浏览器。
  2. 将刚才生成的excel放到压缩包中,即使用ZIPARCHIVE扩展,然后删除临时文件,最后将压缩包输出到浏览器下载
	/**
     * 导出压缩包
     * @param $msgList
     */
    public function getMsgZip($msgList)
    {
        $fileNameArr = [];
        foreach ($msgList as $one) {
            // 列标题
            $expCellName = $one["fields"];
            // 表单名称
            $formTitle = $one["formTitle"];
            // 生成excel
            $this->exportSingleExcel($formTitle . "--留言列表", $expCellName, $one["msgList"], $fileNameArr);
        }
        //进行多个文件压缩
        $zip = new ZipArchive();
        $zipName = "简历--" . date("YmdHis") . ".zip";
        $filename = "../runtime/" . $zipName;
//        $filename = iconv('utf-8','gbk//ignore',$filename);
        $zip->open($filename,  ZIPARCHIVE::CREATE);   //打开压缩包

        //向压缩包中添加文件
        foreach ($fileNameArr as $file) {
            $a = $zip->addFromString($file["title"],file_get_contents($file["file"])); //向压缩包中添加文件
        }
        $zip->close();  //关闭压缩包
        foreach ($fileNameArr as $file) {
            unlink($file["file"]); //删除csv临时文件
        }
        //输出压缩文件提供下载
        header("Cache-Control: max-age=0");
        header("Content-Description: File Transfer");
        header('Content-disposition: attachment; filename='.$zipName); // 文件名
        header("Content-Type: application/zip"); // zip格式的
        header("Content-Transfer-Encoding: binary"); //
        header('Content-Length: '.filesize($filename)); //
        ob_clean();
        flush();
        readfile($filename);//输出文件;
        unlink($filename); //删除压缩包临时文件
    }

压缩包中的单个excel

public function exportSingleExcel($expTitle, $expCellName, $expTableData, &$fileNameArr)
    {
        $expTitle = $expTitle . "-" . time();
        $spreadsheet = new Spreadsheet();
        $worksheet = $spreadsheet->getActiveSheet();
        // excel第一行:数据标题
        $titleColumnIndex = 1;
        foreach ($expCellName as $key => $value) {
            $worksheet->setCellValueByColumnAndRow($titleColumnIndex, 1, $value);
            $titleColumnIndex++;
        }
        foreach ($expTableData as $key => $value) {
            $j = $key + 2;
            $columnIndex = 1;
            foreach ($expCellName as $k => $v) {
                $columnIndexData = isset($value[$k]) ? $value[$k] : "";
                $worksheet->setCellValueByColumnAndRow($columnIndex, $j, $columnIndexData);
                $columnIndex++;
            }
        }
        $expName = "../runtime/" . $expTitle . '.xls';
        header('pragma:public');
        header('Content-type:application/vnd.ms-excel;charset=utf-8;name=' . $expName);
        header("Content-Disposition:attachment;filename=$expName");//attachment新窗口打印inline本窗口打印
        $fileNameArr[] = [
            "title" => $expTitle . '.xls',
            "file" => $expName,
        ];
        $objWriter = IOFactory::createWriter($spreadsheet, 'Xlsx');
        $objWriter->save($expName);
    }

扩展:常规excel下载

	/**
     * 导出 数组转换成excel内容
     * @param string $expTitle 文件名
     * @param array $expCellName 列名
     * @param array $expTableData 数据,二维数组,格式:[["name"=>"小明","age"=>"18"],["name"=>"小红","age"=>"17"]]
     * @throws \PhpOffice\PhpSpreadsheet\Writer\Exception
     */
    public static function exportExcel($expTitle, $expCellName, $expTableData)
    {
        $expTitle = $expTitle . "-" . date("YmdHis");
        $spreadsheet = new Spreadsheet();
        $worksheet = $spreadsheet->getActiveSheet();
        // excel第一行:数据标题
        $titleColumnIndex = 1;
        foreach ($expCellName as $key => $value) {
            $worksheet->setCellValueByColumnAndRow($titleColumnIndex, 1, $value);
            $titleColumnIndex++;
        }
        // excel数据
        if (!empty($expTableData)) {
            foreach ($expTableData as $key => $value) {
                $j = $key + 2;
                $columnIndex = 1;
                foreach ($expCellName as $k => $v) {
                    $columnIndexData = isset($value[$k]) ? $value[$k] : "";
                    $worksheet->setCellValueByColumnAndRow($columnIndex, $j, $columnIndexData);
                    $columnIndex++;
                }
            }
        }
        header('pragma:public');
        header('Content-type:application/vnd.ms-excel;charset=utf-8;name="' . $expTitle . '.xls"');
        header("Content-Disposition:attachment;filename=$expTitle.xls");//attachment新窗口打印inline本窗口打印
        $objWriter = IOFactory::createWriter($spreadsheet, 'Xlsx');
        $objWriter->save('php://output');
//        exit;
    }
  PHP知识库 最新文章
Laravel 下实现 Google 2fa 验证
UUCTF WP
DASCTF10月 web
XAMPP任意命令执行提升权限漏洞(CVE-2020-
[GYCTF2020]Easyphp
iwebsec靶场 代码执行关卡通关笔记
多个线程同步执行,多个线程依次执行,多个
php 没事记录下常用方法 (TP5.1)
php之jwt
2021-09-18
上一篇文章      下一篇文章      查看所有文章
加:2021-07-15 15:56:45  更:2021-07-15 15:58:55 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/7 17:27:37-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码