在现在的项目里,不管是电商项目还是别的项目,在管理端都会有导出的功能,比方说订单表导出,用户表导出,业绩表导出。这些都需要提前生成excel表,然后在导出,实际上是在代码里生成一张excel表,然后通过下载api进行导出的。好了 先给大家讲一下示例
利用php导出excel我们大多会直接生成.xls文件,这种方便快捷。
首先我们先在项目中引入几个类

use \PhpOffice\PhpSpreadsheet\Spreadsheet;
use \PhpOffice\PhpSpreadsheet\IOFactory;
use \PhpOffice\PhpSpreadsheet\Cell\Coordinate;
use PhpOffice\PhpSpreadsheet\Style\Border;
use PhpOffice\PhpSpreadsheet\Style\Alignment;

然后我们在进行封装一个生成并导出excel表的方法,这里我们用订单表做示例

//订单信息导出excelpublic function order_outputProjectExcel($info){$newExcel = new Spreadsheet();//创建一个新的excel文档$objSheet = $newExcel->getActiveSheet();//获取当前操作sheet的对象$date = date('Ymd',time());$name = '订单信息表';$objSheet->setTitle($name);//设置当前sheet的标题//样式设置 - 合并和拆分$objSheet->mergeCells('A1:P1'); //合并单元格//$sheet -> unmergeCells('C3:G3'); //拆分单元格$objSheet->setCellValue('A1',$name);//设置第一栏的中文标题$objSheet->setCellValue('A2', '编号')->setCellValue('B2', '商品图片')->setCellValue('C2', '商品名称')->setCellValue('D2', '会员编号')->setCellValue('E2', '直属')->setCellValue('F2', '非直属')->setCellValue('G2', '订单号')->setCellValue('H2', '商品单价')->setCellValue('I2', '实付金额')->setCellValue('J2', '商品佣金')->setCellValue('K2', '会员佣金')->setCellValue('L2', '直属佣金')->setCellValue('M2', '非直属佣金')->setCellValue('N2', '支付时间')->setCellValue('O2', '支付渠道')->setCellValue('P2', '订单状态');//写入数据$dataCount = count($info);$k = 2;if($dataCount == 0){exit;}else{for ($i=0;$i<$dataCount;$i++){$k = $k + 1;$order=$i+1;$objSheet->setCellValue('A' . $k, $info[$i]['id'])->setCellValue('B' . $k, $info[$i]['goods_image'])->setCellValue('C' . $k, $info[$i]['goods_name'])->setCellValue('D' . $k, $info[$i]['user_num'])->setCellValue('E' . $k, $info[$i]['user_upteam'])->setCellValue('F' . $k, $info[$i]['user_un_upteam'])->setCellValue('G' . $k, $info[$i]['order_id'])->setCellValue('H' . $k, $info[$i]['goods_price'])->setCellValue('I' . $k, $info[$i]['payment'])->setCellValue('J' . $k, $info[$i]['goods_yongjin'])->setCellValue('K' . $k, $info[$i]['user_yongjin'])->setCellValue('L' . $k, $info[$i]['user_up_yongjin'])->setCellValue('M' . $k, $info[$i]['user_un_upyongjin'])->setCellValue('N' . $k, $info[$i]['paymenttime'])->setCellValue('O' . $k, $info[$i]['pay_way_ch'])->setCellValue('P' . $k, $info[$i]['status_ch']);}}//设定样式//所有sheet的表头样式 加粗$font = ['font' => ['bold' => true,'size' => 14,],];$objSheet->getStyle('A1:P1')->applyFromArray($font);//样式设置 - 水平、垂直居中$styleArray = ['alignment' => ['horizontal' => Alignment::HORIZONTAL_CENTER,'vertical' => Alignment::VERTICAL_CENTER],];$objSheet->getStyle('A1:P2')->applyFromArray($styleArray);//所有sheet的内容样式-加黑色边框$borders = ['borders' => ['outline' => ['borderStyle' => Border::BORDER_THIN,'color' => ['argb' => '000000'],],'inside' => ['borderStyle' => Border::BORDER_THIN,]],];$objSheet->getStyle('A1:P'.$k)->applyFromArray($borders);//设置宽度$cell = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P'];foreach($cell as $k=>$v){$objSheet->getColumnDimension($v)->setWidth(20);//            $objSheet->getColumnDimension($v)->setAutoSize(true);}$this->downloadExcel($newExcel,$name,'Xlsx');}//下载private function downloadExcel($newExcel,$filename,$format){ob_end_clean();ob_start();// $format只能为 Xlsx 或 Xlsif ($format == 'Xlsx') {header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');} elseif ($format == 'Xls') {header('Content-Type: application/vnd.ms-excel');}
//  strtolower($format)header("Content-Disposition: attachment;filename=". $filename . '.' . strtolower($format));header('Cache-Control: max-age=0');$objWriter = IOFactory::createWriter($newExcel, $format);$objWriter->save('php://output');//通过php保存在本地的时候需要用到// $objWriter->save($dir.'/demo.xlsx');//以下为需要用到IE时候设置// If you're serving to IE 9, then the following may be needed//header('Cache-Control: max-age=1');// If you're serving to IE over SSL, then the following may be needed//header('Expires: Mon, 26 Jul 1997 05:00:00 GMT'); // Date in the past//header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT'); // always modified//header('Cache-Control: cache, must-revalidate'); // HTTP/1.1//header('Pragma: public'); // HTTP/1.0exit;}

到这一步其实就已经成功了95%了。剩下的5%只需要你调用上面的方法传入正确的参数即可

model('Apimodel')->order_outputProjectExcel($info);

这里的$info是你的订单详情。必须要做时间筛选,如果不做时间筛选的话 数据量一多,你的系统会崩的。
这里的for循环就是你传入的 $info。 如果说你的 $info 是空的 那么导出的excel打开的时候还会出现

for ($i=0;$i<$dataCount;$i++){$k = $k + 1;$order=$i+1;$objSheet->setCellValue('A' . $k, $info[$i]['id'])->setCellValue('B' . $k, $info[$i]['goods_image'])->setCellValue('C' . $k, $info[$i]['goods_name'])->setCellValue('D' . $k, $info[$i]['user_num'])->setCellValue('E' . $k, $info[$i]['user_upteam'])->setCellValue('F' . $k, $info[$i]['user_un_upteam'])->setCellValue('G' . $k, $info[$i]['order_id'])->setCellValue('H' . $k, $info[$i]['goods_price'])->setCellValue('I' . $k, $info[$i]['payment'])->setCellValue('J' . $k, $info[$i]['goods_yongjin'])->setCellValue('K' . $k, $info[$i]['user_yongjin'])->setCellValue('L' . $k, $info[$i]['user_up_yongjin'])->setCellValue('M' . $k, $info[$i]['user_un_upyongjin'])->setCellValue('N' . $k, $info[$i]['paymenttime'])->setCellValue('O' . $k, $info[$i]['pay_way_ch'])->setCellValue('P' . $k, $info[$i]['status_ch']);}

最后就是这样的效果
不懂的可以留言。。。

使用php 实现生成Excel文件并导出相关推荐

  1. java ajax 导出excel文件_springMVC(4)---生成excel文件并导出

    springMVC(4)---生成excel文件并导出 在开发过程中,需要将数据库中的数据以excel表格的方式导出. 首先说明.我这里用的是Apache的POI项目,它是目前比较成熟的HSSF接口, ...

  2. php mysql生成excel文件,PHP导出MySQL数据到Excel文件简单示例

    这篇文章主要为大家详细介绍了PHP导出MySQL数据到Excel文件简单示例,具有一定的参考价值,可以用来参考一下. 对phpPHP导出MySQL数据到Excel文件简单示例感兴趣的小伙伴,下面一起跟 ...

  3. 获取jqGrid中的所有数据导出并生成Excel文件流供用户下载(post请求实现文件下载)...

    最近有一个需求是: 将jqGrid表格中的数据生成报表Excel文件返回给用户. 我的想法是获取jqGrid中的数据然后生成json数据,传给后端,生成文件流,响应到前端,保存为excel文件. aj ...

  4. 项目总结23:POI生成Excel文件并浏览器导出

    项目总结23:POI生成Excel文件并浏览器导出 具体的逻辑可以参考Controller层的注释 代码1-前端html <button onclick="downLoad()&quo ...

  5. Html 中表格导出生成excel文件,解决中文导出失败问题。

    Html 中表格导出生成excel文件,解决中文导出失败问题. 网上有Github的jquery插件,但是表格中含有中文的时候,会导出失败,jquery.base64出现INVALID_CHARACT ...

  6. java导出excel文件_POI生成EXCEL文件

    一.背景 根据指定格式的JSON文件生成对应的excel文件,需求如下 支持多sheet 支持单元格合并 支持插入图片 支持单元格样式可定制 需要 标题(title),表头(head),数据(data ...

  7. poi导出excel 损坏_Java使用POI生成Excel文件后打不开的问题

    在实际的工作中,有时会遇到获取数据后需要存入Excel文件的情况.但是,在生成Excel文件后,发现无法正常打开该文件. 例如:以当前的时间点为文件名,新生成一个Excel文件.先来看看下面一段代码. ...

  8. java导出excel 打不开_Java使用POI生成Excel文件后打不开的问题

    在实际的工作中,有时会遇到获取数据后需要存入Excel文件的情况.但是,在生成Excel文件后,发现无法正常打开该文件. 例如:以当前的时间点为文件名,新生成一个Excel文件.先来看看下面一段代码. ...

  9. bcp生成excel文件优化方案

    一.综述:目前页面生成excel的方法很多,总结起来,不外乎两类,一种是使用excel对象,一种是"伪文件".两种方法 是各自有各自的优缺点,在不同的领域也都有很多成功的案例.前者 ...

最新文章

  1. Error in sort.int(x, na.last = na.last, decreasing = decreasing, ...) : ‘x‘ must be atomic
  2. 专访 CNCF 大使张磊:让云原生不再是大厂专属
  3. java if else 过多_Java中if-else过多怎么解决
  4. 面试集——redis
  5. 第四篇 群聚类非线性表的编程实验 第11章 应用图的遍历算法编程
  6. 谈谈C#的私有成员的一个有趣的现象!
  7. 服务器系统网卡驱动装不上,网卡驱动装不上去怎么办?
  8. java如何让线程阻塞_Java中如何使一个线程进入阻塞态?
  9. js 字符串插入_前端利器React,为什么推荐JSX来替换JS
  10. 音视频开发(40)---麦克风阵列声源定位 GCC-PHAT
  11. 关于BS7799-3
  12. 十个值得所有极客收藏的网站
  13. 女人,百花千红你最美
  14. 2022 年 React Native 的全新架构更新
  15. Anciety 0CTF/TCTF 2018 总结
  16. 计算机视觉——Harris角点检测(课堂实验)
  17. [OMNET++]ALOHA协议
  18. 专业商标制作,免费logo在线设计
  19. 实现74LVC161的计数器功能
  20. java计算机毕业设计技术的游戏交易平台源代码+数据库+系统+lw文档

热门文章

  1. R语言:企业风险分析(4)【输入建模,拟合概率分布法】
  2. 人生经典定律[收藏] 1
  3. 【Dart 教程系列第 10 篇】Dart 之 removeLast 删除数组的最后一个元素
  4. Springboot毕设项目华阳大众汽车售卖系统v9f90(java+VUE+Mybatis+Maven+Mysql)
  5. CA6140车床法兰盘零件机械加工工艺规程及钻3-11 孔工序专用夹具设计
  6. 关于滤波电容、去耦电容(相当电池10u或者更大)、旁路电容(对无用的高频信号提供释放通道0.1u0.01u)作用及其原理
  7. 阿里妈妈广告进入联合早报网
  8. pycharm连接mysql5.7
  9. Java实现利用QQ邮箱发送邮件
  10. 工信部叫停苹果 Callkit,微信不能直接接听视频了