PHPEXCEL 封装

    public function excelExport($xlsCell, $xlsData, $xlsName)
    {
        require(Env::get('root_path') . 'vendor/PHPExcel/PHPExcel.php');
        $objPHPExcel = new \PHPExcel();

        //Set properties 设置文件属性
        $objPHPExcel->getProperties()->setCreator("Maarten Balliauw");
        $objPHPExcel->getProperties()->setLastModifiedBy("Maarten Balliauw");
        $objPHPExcel->getProperties()->setTitle("Office 2007 XLSX Test Document");
        $objPHPExcel->getProperties()->setSubject("Office 2007 XLSX Test Document");
        $objPHPExcel->getProperties()->setDescription("Test document for Office 2007 XLSX, generated using PHP classes.");
        $objPHPExcel->getProperties()->setKeywords("office 2007 openxml php");
        $objPHPExcel->getProperties()->setCategory("Test result file");

        //表头
        $column = 1;
        $span = ord("A");
        foreach ($xlsCell as $v) {
            $j = chr($span);
            $objPHPExcel->setActiveSheetIndex(0)->setCellValue($j . $column, $v['1']);
            $span++;
        }

        $column++;
        $objActSheet = $objPHPExcel->getActiveSheet();

        foreach ($xlsData as $key => $rows) {
            $span = ord('A');
            foreach ($xlsCell as $value) {
                $j = chr($span);
                //判断是不是时间戳
                if (is_int($rows[$value['0']])) {
                    if (strtotime(date('Y-m-d H:i:s', $rows[$value['0']])) === $rows[$value['0']]) {
                        $rows[$value['0']] = date('Y-m-d H:i:s', $rows[$value['0']]);
                    }
                }
                $objActSheet->setCellValue($j . $column, $rows[$value['0']]);
                $span++;
            }
            $column++;
        }

        $objPHPExcel->setActiveSheetIndex(0);

        ob_end_clean();
        ob_start();

        header("Content-Type: application/force-download");
        header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
        header("Content-Disposition:attachment;filename =" . str_ireplace('+', '%20', URLEncode($xlsName)) . '.xlsx');
        header('Cache-Control: max-age=0');

        $objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');
        $objWriter->save('php://output');
        exit;
    }

导出数据

  public function alllog(Request $request)
    {
        $data = $request->param();
        $where = [];
        $list = Alllog::where($where)->order('id desc')->all();

        //导出
        $xlsData = $list;
        $xlsName = "进出厂记录表";
        $xlsCell = array(
            array('carNum', '车牌', 20),
            array('one_gate', '第一入闸门时间', 40),
        );
        $this->excelExport($xlsCell, $xlsData, $xlsName);

    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值