php封装excel下载类,使用phpspreadsheet

1、下载composer包

在composer.json的require中加入,引入包文件

"phpoffice/phpspreadsheet": "^1.3",

2、封装类文件到项目中

<?php

namespace common\helpers;

use Yii;
use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PhpOffice\PhpSpreadsheet\Cell\DataType;
use PhpOffice\PhpSpreadsheet\IOFactory;


class ExportHelper
{
    /**
     * $columnNames = ['用户', '手机号', '反馈类型', '留言', '反馈时间'];
     * $columnData[] = ['张三','15880xxxxxx','','',''];
     * param $rowList = ['title' =>   '反馈' . date('His') . '.xlsx','columnName' => $columnNames,'columnData' => $columnData];
     */
    public static function exportData($rowList=[])
    {

//        var_dump($rowList);die;

        set_time_limit(0);
        // Create new Spreadsheet object
        $spreadsheet = new Spreadsheet();

        // Set document properties
        $spreadsheet->getProperties()->setCreator('Maarten Balliauw')
            ->setLastModifiedBy('Maarten Balliauw')
            ->setTitle('Office 2007 XLSX Test Document')
            ->setSubject('Office 2007 XLSX Test Document')
            ->setDescription('Test document for Office 2007 XLSX, generated using PHP classes.')
            ->setKeywords('office 2007 openxml php')
            ->setCategory('Test result file');

        //
//        $spreadsheet->setActiveSheetIndex(0);
        $activeSheet = $spreadsheet->setActiveSheetIndex(0);
        foreach ($rowList['columnName'] as $key => $value)
        {
            $activeSheet->setCellValueByColumnAndRow($key + 1, 1, $value);
        }

        $col = 0;

        foreach ($rowList['columnData'] as $row => $item)
        {
            foreach ($item as $col => $value)
            {
                Yii::info($value['val']);
                $activeSheet->getCellByColumnAndRow($col + 1, $row + 2)->setValueExplicit($value['val'], DataType::TYPE_STRING);
                //$activeSheet->setCellValueByColumnAndRow($col + 1, $row + 2, "".$value['val']);
            }
        }

        $spreadsheet->getActiveSheet()->setTitle('数据');

        // Set active sheet index to the first sheet, so Excel opens this as the first sheet
        $spreadsheet->setActiveSheetIndex(0);

        $filename = $rowList['title'];
        // Redirect output to a client’s web browser (Xls)
        header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
        header('Content-Disposition: attachment;filename=' . $filename);
        header('Cache-Control: max-age=0');
        // If you're serving to IE 9, then the following may be needed
        header('Cache-Control: max-age=1');

        // If you're serving to IE over SSL, then the following may be needed
        header('Expires: Mon, 26 Jul 1997 05:00:00 GMT'); // Date in the past
        header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT'); // always modified
        header('Cache-Control: cache, must-revalidate'); // HTTP/1.1
        header('Pragma: public'); // HTTP/1.0

        $writer = IOFactory::createWriter($spreadsheet, 'Xlsx');
        $writer->save('php://output');
        exit;
    }
}

3、使用(参数可以参考封装类的提示)

$rowList = [
    'title' =>   '反馈' . date('His') . '.xlsx',
    'columnName' => $columnNames,
    'columnData' => $columnData
];

ExportHelper::exportData($rowList);  //记得引入命名空间

 

这样子,直接调用封装的类后,之后php将数据下载成excel就简单啦 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值