thinkphp5.1 使用phpoffice/phpspreadsheet导出excel

PHPExcel已经被废弃在PHP7.2中已经无法获取更新,官方重新开了一个新包phpspreadsheet

composer安装:电脑/服务器上安

composer require phpoffice/phpspreadsheet

  以下为后台PHP代码

use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
use think\facade\Cache;
 $xlsName = "文件" . date("YmdHis", time());
        $head = ['日期', '付款人数', '付款订单数', '付款金额', '付款件数'];// 表头信息
        $keys = ['time', 'order_num', 'did', 'total_price', 'good_num'];
        $this->downloadExcel($xlsName, $list['data'], $head, $keys);// 传递参数
//报表导出核心方法
    //* 导出excel表
    //* $data:要导出excel表的数据,接受一个二维数组
    //* $name:excel表的表名
    //* $head:excel表的表头,接受一个一维数组
    //* $key:$data中对应表头的键的数组,接受一个一维数组
    //* 备注:此函数缺点是,表头(对应列数)不能超过26;
    //*循环不够灵活,一个单元格中不方便存放两个数据库字段的值

    public function downloadExcel($name = '测试表', $data = [], $head = [], $keys = [])
    {
        $count = count($head);  //计算表头数量
        $spreadsheet = new Spreadsheet();
        $sheet = $spreadsheet->getActiveSheet();

        for ($i = 65; $i < $count + 65; $i++) {     //数字转字母从65开始,循环设置表头:
            $sheet->setCellValue(strtoupper(chr($i)) . '1', $head[$i - 65]);
        }
        foreach ($data as $key => $item) {             //循环设置单元格:
            //$key+2,因为第一行是表头,所以写到表格时   从第二行开始写
            for ($i = 65; $i < $count + 65; $i++) {     //数字转字母从65开始:
                $sheet->setCellValue(strtoupper(chr($i)) . ($key + 2), $item[$keys[$i - 65]]);
                $spreadsheet->getActiveSheet()->getColumnDimension(strtoupper(chr($i)))->setWidth(20); //固定列宽
            }

        }
        header('Content-Type: application/vnd.ms-excel');
        header('Content-Disposition: attachment;filename="' . $name . '.xlsx"');
        header('Cache-Control: max-age=0');
        $writer = new Xlsx($spreadsheet);
        $writer->save('php://output');

        //删除清空:
        $spreadsheet->disconnectWorksheets();
        unset($spreadsheet);
        return;
    }

 

你可能感兴趣的:(php)