PHPExcel用法有感
今日项目需求导出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用法有感的更多相关文章
- PHPExcel用法
<?php //下面是总结的几个使用方法 include 'PHPExcel.php'; include 'PHPExcel/Writer/Excel2007.php'; //或者include ...
- phpexcel用法(转)
.php导出excel(多种方法) (2013-03-23 15:44:02) 转载▼ 分类: php 基本上导出的文件分为两种: 1:类Excel格式,这个其实不是传统意义上的Excel文件,只 ...
- php中使用PHPExcel操作excel(xls)文件
读取中文的xls.csv文件会有问题,网上找了下资料,发现PHPExcel类库好用,官网地址:http://phpexcel.codeplex.com/ 1.读取xls文件内容 代码如下 复制代码 ...
- PHP从数据库导出EXCEL文件
参考博客链接:http://www.cnblogs.com/huangcong/p/3687665.html 我的程序代码 原生导出Excel文件 <?phpheader('Content-ty ...
- php更新修改excel中的内容例子
代码如下 复制代码 //模板存放目录$dir = $DOCUMENT_ROOT.'/backoffice/admin/oemcheck/'; $templateName = '1.xlsx';$ou ...
- C#高级编程(第9版) 第10章 集合 笔记
话说 虽然敲过好多代码, 但除了C++,一直没正眼瞧过其它语言.(没办法 谁叫C++既有oop又能自由控制内存呢) 今天 看公司老项目的src,c#的,linq+Dictionary的用法有感.所以找 ...
- 项目中phpexcel的基本用法
前提:要下载PHPEXCEL库文件 如:phpexcel官方下载 ,本人使用下载 情形一:对于将数据写入EXCEL表中的用法 header("content-type:text/htm ...
- php利用PHPExcel类导出导入Excel用法
PHPExcel类是php一个excel表格处理插件了,下面我来给大家介绍利用PHPExcel类来导入与导出excel表格的应用方法,有需要了解的朋友不防参考参考(PHPExcel自己百度下载这里不介 ...
- 使用PHPExcel操作Excel用法实例分析
本文实例分析了使用PHPExcel操作Excel用法.分享给大家供大家参考.具体分析如下: PHPExcel下载地址:http://www.codeplex.com/PHPExcel http://w ...
随机推荐
- sae Servlet class XXXX is not a javax.servlet.Servlet
以前都是使用myeclipse开发web工程上传sae后没有问题,但是使用javaee导出war包上传sae 无法访问 Servlet class XXXX is not a javax.servl ...
- 转:exit()与_exit()的区别
版权声明:本文为博主原创文章,未经博主允许不得转载. 从图中可以看出,_exit 函数的作用是:直接使进程停止运行,清除其使用的内存空间,并清除其在内核的各种数据结构:exit 函数则在这些基础上做了 ...
- 委托 delegate, 继承
c# 的委托就是说把函数当参数来传递. 这个在js完全就用不着搞什么委托东西,直接转就是了嘛.对不对!怎么录嘛! 一个函数,如果它的参数是函数,那么是这样子写的 public void method( ...
- Xamarin devexpress datagrid 样式
DevExpress的提供光与暗的内置,可以应用到主题GridControl改变其外观. 主题 iOS版 Android版 光(默认适用于iOS) 黑暗(默认为Android) 应用预定义的主题 ...
- 百度搜索URL参数 搜索关键字
http://www.baidu.com/s?wd=关键字 wd(Keyword):查询的关键词: http://www.baidu.com/s?wd=关键字&cl=3 cl(Class):搜 ...
- jdk各个版本的特性
http://blog.csdn.net/mixiuali/article/details/8180100
- Web Server CA证书签名步骤和自签名测试,支持多域名
Web Server支持HTTPS访问需要两个文件,私钥和证书.私钥和证书都放在服务器上,私钥用来加密数据,证书传递给客户端.自己签名的证书在传递给浏览器的时,因为证书不被信任,所以会弹出连接不安全, ...
- MATLAB获取“非免驱的相机或者摄像头”的图像数据
Image Acquisition Toolbox™ Adaptor Kit 图像採集工具箱 当要使用MATLAB获取"非免驱的相机或者摄像头"的图像数据时,须要开发一个插件,MA ...
- i++与++i的区别,使用实例说明
/** * 类名:TEST.java<br> * <p> * 功能:i++与++i的区别,使用实例说明 * </p> * * @Author:<a href= ...
- 查看android进程信息
打开adb shell.直接ps命令 假设查看某特定进程,比方<圣火英雄传>.用grep过滤 各列參数意义: USER 进程当前用户: PID Pro ...