本文实例讲述了thinkPHP5框架导出Excel文件简单操作。分享给大家供大家参考,具体如下:
1. 首先安装PHPExcel 这里用composer
安装
composer require phpoffice/phpexcel
2. 在控制类引用
use PHPExcel_IOFactory;use PHPExcel;
3. 在控制其中书写导出方法
/** * 导出迟到数据 */public function export_later(){ $date = explode("-",input("get.date")); $_opt["year"] = $date[0]; $_opt["month"] = $date[1]; $laterArray = Db::name("user")->select();//查找user表数据 $xlsName = $_opt["month"]."月迟到早退数据统计"; $xlsCell = array( array("user_name","姓名"), array("user_accounts","工号"), array("later_times","迟到次数"), array("total_later","迟到累计(分钟)"), array("early_times","早退次数"), array("total_early","早退累计(分钟)"), );//查出字段输出对应Excel对应的列名 //公共方法调用 export_excel($xlsName,$xlsCell,$laterArray);}/** * 公共数据导出实现功能 * @param $expTitle 导出文件名 * @param $expCellName 导出文件列名称 * @param $expTableData 导出数据 */function export_excel($expTitle,$expCellName,$expTableData){ $xlsTitle = iconv("utf-8", "gb2312", $expTitle);//文件名称 $fileName = $expTitle . date("_Ymd");//or $xlsTitle 文件名称可根据自己情况设定 $cellNum = count($expCellName); $dataNum = count($expTableData); $objPHPExcel = new PHPExcel();//方法一 $cellName = array("A","B", "C","D", "E", "F","G","H","I", "J", "K","L","M", "N", "O", "P", "Q","R","S", "T","U","V", "W", "X","Y", "Z", "AA", "AB", "AC","AD","AE", "AF","AG","AH","AI", "AJ", "AK", "AL","AM","AN","AO","AP","AQ","AR", "AS", "AT","AU", "AV","AW", "AX", "AY", "AZ"); //设置头部导出时间备注 $objPHPExcel->getActiveSheet(0)->mergeCells("A1:" . $cellName[$cellNum - 1] . "1");//合并单元格 $objPHPExcel->setActiveSheetIndex(0)->setCellValue("A1", $expTitle . " 导出时间:" . date("Y-m-d H:i:s")); //设置列名称 for ($i = 0; $i < $cellNum; $i++) { $objPHPExcel->setActiveSheetIndex(0)->setCellValue($cellName[$i] . "2", $expCellName[$i][1]); } //赋值 for ($i = 0; $i < $dataNum; $i++) { for ($j = 0; $j < $cellNum; $j++) { $objPHPExcel->getActiveSheet(0)->setCellValue( $cellName[$j] . ($i + 3), $expTableData[$i][$expCellName[$j][0]] ); } } ob_end_clean();//这一步非常关键,用来清除缓冲区防止导出的excel乱码 header("pragma:public"); header("Content-type:application/vnd.ms-excel;charset=utf-8;name="" . $xlsTitle . ".xls""); header("Content-Disposition:attachment;filename=$fileName.xls");//"xls"参考下一条备注 $objWriter = PHPExcel_IOFactory::createWriter( $objPHPExcel, "Excel5" );//"Excel2007"生成2007版本的xlsx,"Excel5"生成2003版本的xls $objWriter->save("php://output");}
更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《Zend FrameWork框架入门教程》及《PHP模板技术总结》。
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。