今日项目需求导出excel。我用最简单的header头方式导出了,但是需求部门退回了,说不满足他们的需求,需要我按照他们的模板来导出。

然后想到了PHPExcel,没用过,走了不少弯路。

1.去官网下载最新的包。

2.普通的导出(和普通Header头导出的一样)。

                 import("Org.Util.PHPExcel");
import("Org.Util.PHPExcel.Writer.Excel5");
import("Org.Util.PHPExcel.IOFactory.php");
import("Org.Util.PHPExcel.Worksheet.Drawing");
$date = date("Y_m_d",time());
$fileName = $date.".xls";
$objPHPExcel = new \PHPExcel();
$objProps = $objPHPExcel->getProperties();
$objActSheet = $objPHPExcel->setActiveSheetIndex(0);
$objActSheet->setCellValue('A1', '订单号');
$objActSheet->setCellValue('B1', '退货单号');
$objActSheet->setCellValue('C1', '生成时间');
$objActSheet->setCellValue('D1', '商品名称');
$objActSheet->setCellValue('E1', '物料编码');
$objActSheet->setCellValue('F1', '退货工单号');
$objActSheet->setCellValue('G1', '退款单号');
$n=2;
foreach($list as $value){
$where = array(
'back_id'=>$value['back_id']
);
$getDetial = $db->table('back_goods')->where($where)->find();
$objActSheet->setCellValueExplicit('A'.$n, $value['order_sn']);
$objActSheet->setCellValueExplicit('B'.$n, $value['back_sn']);
$objActSheet->setCellValue('C'.$n, date('Y-m-d H:i:s',$value['add_time']));
$objActSheet->setCellValue('D'.$n, $getDetial['goods_name']);
$objActSheet->setCellValue('E'.$n, $getDetial['goods_sn']);
$objActSheet->setCellValue('F'.$n, '');
$objActSheet->setCellValue('G'.$n, '');
$n++;
}
$fileName = iconv("utf-8", "gb2312", $fileName);
header('Content-Type: application/vnd.ms-excel');
header("Content-Disposition: attachment;filename=\"$fileName\"");
header('Cache-Control: max-age=0');
$objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
$objWriter->save('php://output'); //文件通过浏览器下载

3.写入到模板excel。

 import("Org.Util.PHPExcel");
import("Org.Util.PHPExcel.Writer.Excel5");
import("Org.Util.PHPExcel.IOFactory.php");
import("Org.Util.PHPExcel.Worksheet.Drawing");
$PHPReader = new \PHPExcel_Reader_Excel5();
$fileName="./Public/a.xls";
$PHPExcel = $PHPReader->load($fileName);
$objActSheet = $PHPExcel->getSheet(0);
$allColumn = $objActSheet->getHighestRow();
$n=1+$allColumn;
if($data){
foreach($data as $k=>$v){
$objActSheet->setCellValue('A'.$n, $k+1);//编号
$objActSheet->setCellValue('B'.$n, $v['name']);//姓名
$n++;
}
}
$objWriter = new \PHPExcel_Writer_Excel5($objPHPExcel);
$objWriter->save($fileName);

4.根据模板写入,并不改变模板,另存为下载。

 import("Org.Util.PHPExcel");
import("Org.Util.PHPExcel.Writer.Excel5");
import("Org.Util.PHPExcel.IOFactory.php");
import("Org.Util.PHPExcel.Worksheet.Drawing");
$PHPReader = new \PHPExcel_Reader_Excel5();
$fileName="./Public/a.xls";
$PHPExcel = $PHPReader->load($fileName);
$objActSheet = $PHPExcel->getSheet(0);
$allColumn = $objActSheet->getHighestRow();
$n=1+$allColumn;
if($data){
foreach($data as $k=>$v){
$objActSheet->setCellValue('A'.$n, $k+1);//编号
$objActSheet->setCellValue('B'.$n, $v['name']);//姓名
$objActSheet->setCellValue('C'.$n, "");//性别?
$n++;
}
}
$file_name="test.xls";
$fileName = iconv("utf-8", "gb2312", $file_name);
header('Content-Type: application/vnd.ms-excel');
header("Content-Disposition: attachment;filename=\"$fileName\"");
header('Cache-Control: max-age=0');
$objWriter = \PHPExcel_IOFactory::createWriter($PHPExcel, 'Excel5');
$objWriter->save('php://output'); //文件通过浏览器下载

注:如果遇到xlsx模板,把new类改成2007即可。普通的xls模板直接5

PHPExcel用法有感的更多相关文章

  1. PHPExcel用法

    <?php //下面是总结的几个使用方法 include 'PHPExcel.php'; include 'PHPExcel/Writer/Excel2007.php'; //或者include ...

  2. phpexcel用法(转)

    .php导出excel(多种方法) (2013-03-23 15:44:02) 转载▼   分类: php 基本上导出的文件分为两种: 1:类Excel格式,这个其实不是传统意义上的Excel文件,只 ...

  3. php中使用PHPExcel操作excel(xls)文件

    读取中文的xls.csv文件会有问题,网上找了下资料,发现PHPExcel类库好用,官网地址:http://phpexcel.codeplex.com/ 1.读取xls文件内容  代码如下 复制代码 ...

  4. PHP从数据库导出EXCEL文件

    参考博客链接:http://www.cnblogs.com/huangcong/p/3687665.html 我的程序代码 原生导出Excel文件 <?phpheader('Content-ty ...

  5. php更新修改excel中的内容例子

    代码如下 复制代码 //模板存放目录$dir = $DOCUMENT_ROOT.'/backoffice/admin/oemcheck/';  $templateName = '1.xlsx';$ou ...

  6. C#高级编程(第9版) 第10章 集合 笔记

    话说 虽然敲过好多代码, 但除了C++,一直没正眼瞧过其它语言.(没办法 谁叫C++既有oop又能自由控制内存呢) 今天 看公司老项目的src,c#的,linq+Dictionary的用法有感.所以找 ...

  7. 项目中phpexcel的基本用法

    前提:要下载PHPEXCEL库文件 如:phpexcel官方下载    ,本人使用下载 情形一:对于将数据写入EXCEL表中的用法 header("content-type:text/htm ...

  8. php利用PHPExcel类导出导入Excel用法

    PHPExcel类是php一个excel表格处理插件了,下面我来给大家介绍利用PHPExcel类来导入与导出excel表格的应用方法,有需要了解的朋友不防参考参考(PHPExcel自己百度下载这里不介 ...

  9. 使用PHPExcel操作Excel用法实例分析

    本文实例分析了使用PHPExcel操作Excel用法.分享给大家供大家参考.具体分析如下: PHPExcel下载地址:http://www.codeplex.com/PHPExcel http://w ...

随机推荐

  1. asp.net2.0app开发。

    asp.net app 网站开发:http://www.cnblogs.com/TerryFeng/archive/2009/05/15/1457731.html 在OPERA或M3GATE中设置编码 ...

  2. XJOI网上同步测试DAY14 T3

    思路:tarjan把桥找出来,然后缩点,注意这里的缩点是:如果两个点之间的连边不是桥,那么就把他们缩起来,然后用一个lct维护,对于每个询问,如果官道连接的是两个联通块的话,就把他们连起来,否则我们就 ...

  3. 【HDOJ】1080 Human Gene Functions

    DP.wa了一下午,原来是把mmax写在外层循环了.最近事情太多了,刷题根本没状态. #include <cstdio> #include <cstring> #include ...

  4. Vim--写在开始

    这是Vim的学习记录,结合Vim使用技巧一书.

  5. eclipse tomcat 网页404的一个小问题

    之前一篇文章说过关于修改tomcat布置的应用的localhost路径.因为有两个项目在eclipse,所以我每次启动tomcat的时候都会加载两个项目, 但我其实只用调试其中一个项目,所以我就在se ...

  6. Apache HttpComponents Client 4.0快速入门/升级-2.POST方法访问网页

    Apache HttpComponents Client 4.0已经发布多时,httpclient项目从commons子项目挪到了HttpComponents子项目下,httpclient3.1和 h ...

  7. Android学习【Android内核编译流程和错误笔记】

    博客:http://blog.csdn.net/muyang_ren Ubuntu14.04 LTS(要求是64位长期支持版LTS) Jdk1.8 内核:android4.0 一:jdk 1.解压jd ...

  8. 全文搜索-介绍-elasticsearch-definitive-guide翻译

    全文搜索 我们通过前文的简单样例,已经了解了结构化数据的条件搜索:如今.让我们来了解全文搜索-- 如何通过匹配全部域的文本找到最相关的文章. 关于全文搜索有两个最重要的方面: 相似度计算 通过TF/I ...

  9. JDK版本错误:Unsupported major.minor version 51.0

    错误原因 有时候把项目从本机编译文件部署到服务器,或者发给别人使用时,会报如下异常: java.lang.UnsupportedClassVersionError: test_hello_world ...

  10. -bash: mysql: command not found 解决办法 (转)

    root@DB-02 ~]# mysql -u root-bash: mysql: command not found 原因:这是由于系统默认会查找/usr/bin下的命令,如果这个命令不在这个目录下 ...