thinkphp excel导出
给大家复习下关键thinkphp excel导出的方法, 首先第一步先直接去下载个 PHPEXCEL包吧,然后就根据以下方法去掉调用下,具体如何引用每个框架引用不一样,按框架去引用。下面方法是公用的
$fileName 是文件名如 $fileName=‘test’
$headArr是个数组如 $headArr=array(头一,头二,头三)
$data 是个数组 如
$data = array(); /*循环出数据*/ for($i=1;$i<9;$i++){ /*基础数据*/ $data[$i] = date('Y-m-d',$v['data']);//日期
}
注意:头的位置要与值的位置对应不是会乱掉的
如头一对$data[0]的值哦,总的来说就是横向一一对应
/** * 表格导出方法 * @param $fileName 文件名 * @param $headArr 表格头 * @param $data 表格内容 */ public function getExcel($fileName,$headArr,$data){ /*导入PHPExcel类库,因为PHPExcel没有用命名空间,只能inport导入*/ import("Org.Util.PHPExcel"); import("Org.Util.PHPExcel.Writer.Excel5"); import("Org.Util.PHPExcel.IOFactory.php");
/*表格名称加上后缀*/ $fileName = "{$fileName}.xls";
/*创建PHPExcel对象,注意,不能少了*/ $objPHPExcel = new \PHPExcel();
/*设置表头*/ $key = ord("A"); foreach($headArr as $v){ $colum = chr($key); $objPHPExcel->setActiveSheetIndex(0) ->setCellValue($colum.'1', $v); $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->setCellValue($j.$column, $value); $span++; } $column++; }
//设置活动单指数到第一个表,所以Excel打开这是第一个表 $objPHPExcel->setActiveSheetIndex(0); ob_end_clean();//清除缓冲区,避免乱码 header('Content-Type: application/vnd.ms-excel;charset=UTF-8'); header("Content-Disposition: attachment;filename={$fileName}"); header('Cache-Control: max-age=0'); $objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5'); $objWriter->save('php://output'); //文件通过浏览器下载 exit; }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)