当前位置:首页 > CMS教程 > Thinkphp > 列表

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

发布:smiling 来源: PHP粉丝网  添加日期:2021-10-22 09:24:31 浏览: 评论:0 

这篇文章主要介绍了thinkPHP5框架导出Excel文件简单操作,结合实例形式分析了thinkPHP5框架安装及使用PHPExcel插件实现导出Excel格式文件的相关操作技巧,需要的朋友可以参考下。

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

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

composer require phpoffice/phpexcel

2. 在控制类引用

use PHPExcel_IOFactory;

use PHPExcel;

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

  1. /** 
  2.  * 导出迟到数据 
  3.  */ 
  4. public function export_later() 
  5.   $date = explode("-",input("get.date")); 
  6.   $_opt['year'] = $date[0]; 
  7.   $_opt['month'] = $date[1]; 
  8.   $laterArray = Db::name('user')->select();//查找user表数据 
  9.   $xlsName = $_opt['month']."月迟到早退数据统计"
  10.   $xlsCell = array
  11.     array('user_name','姓名'), 
  12.     array('user_accounts','工号'), 
  13.     array('later_times','迟到次数'), 
  14.     array('total_later','迟到累计(分钟)'), 
  15.     array('early_times','早退次数'), 
  16.     array('total_early','早退累计(分钟)'), 
  17.   );//查出字段输出对应Excel对应的列名 
  18.   //公共方法调用 
  19.   export_excel($xlsName,$xlsCell,$laterArray); 
  20. /** 
  21.  * 公共数据导出实现功能 
  22.  * @param $expTitle 导出文件名 
  23.  * @param $expCellName 导出文件列名称 
  24.  * @param $expTableData 导出数据 
  25.  */ 
  26. function export_excel($expTitle,$expCellName,$expTableData
  27.   $xlsTitle = iconv('utf-8''gb2312'$expTitle);//文件名称 
  28.   $fileName = $expTitle . date('_Ymd');//or $xlsTitle 文件名称可根据自己情况设定 
  29.   $cellNum = count($expCellName); 
  30.   $dataNum = count($expTableData); 
  31.   $objPHPExcel = new PHPExcel();//方法一 
  32.   $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'
  33.     'AB''AC','AD','AE''AF','AG','AH','AI''AJ''AK''AL','AM','AN','AO','AP','AQ','AR''AS''AT','AU''AV','AW''AX'
  34.     'AY''AZ'); 
  35.   //设置头部导出时间备注 
  36.   $objPHPExcel->getActiveSheet(0)->mergeCells('A1:' . $cellName[$cellNum - 1] . '1');//合并单元格 
  37.   $objPHPExcel->setActiveSheetIndex(0)->setCellValue('A1'$expTitle . ' 导出时间:' . date('Y-m-d H:i:s')); 
  38.   //设置列名称 
  39.   for ($i = 0; $i < $cellNum$i++) { 
  40.     $objPHPExcel->setActiveSheetIndex(0)->setCellValue($cellName[$i] . '2'$expCellName[$i][1]); 
  41.   } 
  42.   //赋值 
  43.   for ($i = 0; $i < $dataNum$i++) { 
  44.     for ($j = 0; $j < $cellNum$j++) { 
  45.       $objPHPExcel->getActiveSheet(0)->setCellValue( 
  46.         $cellName[$j] . ($i + 3), $expTableData[$i][$expCellName[$j][0]] 
  47.       ); 
  48.     } 
  49.   } 
  50.   ob_end_clean();//这一步非常关键,用来清除缓冲区防止导出的excel乱码 
  51.   header('pragma:public'); 
  52.   header('Content-type:application/vnd.ms-excel;charset=utf-8;name="' . $xlsTitle . '.xls"'); 
  53.   header("Content-Disposition:attachment;filename=$fileName.xls");//"xls"参考下一条备注 
  54.   $objWriter = \PHPExcel_IOFactory::createWriter( 
  55.     $objPHPExcel'Excel5' 
  56.   );//"Excel2007"生成2007版本的xlsx,"Excel5"生成2003版本的xls 
  57.   $objWriter->save('php://output'); 
  58. }

Tags: thinkPHP5导出Excel

分享到: