thinkPHP5框架导出Excel文件简单操作示例

前端之家收集整理的这篇文章主要介绍了thinkPHP5框架导出Excel文件简单操作示例前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

本文实例讲述了thinkPHP5框架导出Excel文件简单操作。分享给大家供大家参考,具体如下:

1. 首先安装PHPExcel 这里用composer安装

PHP;"> composer require PHPoffice/PHPexcel

2. 在控制类引用

PHP;"> use PHPExcel_IOFactory; use PHPExcel;

3. 在控制其中书写导出方法

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相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》、《》及《PHP模板技术总结》。

希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。

原文链接:https://www.f2er.com/thinkphp/15786.html

猜你在找的ThinkPHP相关文章