tp5 导出excel

/*

* execl数据导出

* 应用场景:订单导出

* @param string $fileName模型名(如Member),用于导出生成文件名的前缀

* @param array $headArr表头及字段名

* @param array $data 导出的表数据

* 特殊处理:合并单元格需要先对数据进行处理

*/

public function getExcel(fileName,fileName,fileName,headArr,$data){

// die(empty($data));

    // //对数据进行检验


    if(empty($data) || !is_array($data)){

        die("data must be a array");

    }


    //检查文件名

    if(empty($fileName)){

        exit;

    }

    $date = date("Y_m_d",time());

    $fileName .= "_{$date}.xls";

    //创建PHPExcel对象,注意,不能少了\

    $objPHPExcel = new \PHPExcel();

    $objProps = $objPHPExcel->getProperties();

    //设置表头

    $key = ord("A");

    foreach($headArr as $v){

        $colum = chr($key);

        $objPHPExcel->setActiveSheetIndex(0)->setCellValue($colum.'1', $v);

        $key += 1;

    }

    $column = 2;

    $objActSheet = $objPHPExcel->getActiveSheet();

    //设置为文本格式

    foreach($data as $key => $rows){ //行写入

        $span = ord("A");

        foreach($rows as $keyName=>$value){// 列写入

            $j = chr($span);

            $objActSheet->setCellValueExplicit($j.$column, $value);

            $span++;

        }

        $column++;

    }

    $fileName = iconv("utf-8", "gb2312", $fileName);

    //重命名表

    // $objPHPExcel->getActiveSheet()->setTitle('test');

    //设置活动单指数到第一个表,所以Excel打开这是第一个表

    $objPHPExcel->setActiveSheetIndex(0);

    ob_end_clean();//清除缓冲区,避免乱码

    header('Content-Type: application/vnd.ms-excel');

    header("Content-Disposition: attachment;filename=\"$fileName\"");

    header('Cache-Control: max-age=0');

    $objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');

    $objWriter->save('php://output'); //文件通过浏览器下载

    exit;

}

你可能感兴趣的:(tp5 导出excel)