PHP导出EXCEL快速开发指南--PHPEXCEL的使用详解


Posted in PHP onJune 03, 2013

PHP导出EXCEL快速开发指南
phpexcel有专有的开发文档,详细操作请参考其开发文档,本文档只是对其在使用上作了优化整合,便于在新项目中快速开发。
phpexcel生成文件同样有两种方式,一种方式为直接输出,一种方式为生成静态文件。
直接输出:
主文件为(class目录的同目录文件):

<?php 
include("./class/class.php"); // 包含class的基本头文件
include("./class/phpexcel/PHPExcel.php"); // 生成excel的基本类定义(注意文件名的大小写)
// 如果直接输出excel文件,则要包含此文件
include("./class/phpexcel/PHPExcel/IOFactory.php");
// 创建phpexcel对象,此对象包含输出的内容及格式
$m_objPHPExcel = new PHPExcel();
// 模板文件,为了实现格式与内容分离,有关输出文件具体内容实现在模板文件中
// 模板文件将对象$m_objPHPExcel进行操作
include("./include/excel.php");
// 输出文件的类型,excel或pdf
$m_exportType = "excel";
$m_strOutputExcelFileName = date('Y-m-j_H_i_s').".xls"; // 输出EXCEL文件名
$m_strOutputPdfFileName = date('Y-m-j_H_i_s').".pdf"; // 输出PDF文件名
// PHPExcel_IOFactory, 输出excel
//require_once dirname(__FILE__).'/Classes/PHPExcel/IOFactory.php';
// 如果需要输出EXCEL格式
if($m_exportType=="excel"){
$objWriter = PHPExcel_IOFactory::createWriter($m_objPHPExcel, 'Excel5');
// 从浏览器直接输出$m_strOutputExcelFileName
header("Pragma: public");
header("Expires: 0");
header("Cache-Control:must-revalidate, post-check=0, pre-check=0");
header("Content-Type:application/force-download");
header("Content-Type: application/vnd.ms-excel;");
header("Content-Type:application/octet-stream");
header("Content-Type:application/download");
header("Content-Disposition:attachment;filename=".$m_strOutputExcelFileName);
header("Content-Transfer-Encoding:binary");
$objWriter->save("php://output"); 
}
// 如果需要输出PDF格式
if($m_exportType=="pdf"){
$objWriter = PHPExcel_IOFactory::createWriter($m_objPHPExcel, 'PDF');
$objWriter->setSheetIndex(0);
header("Pragma: public");
header("Expires: 0");
header("Cache-Control:must-revalidate, post-check=0, pre-check=0");
header("Content-Type:application/force-download");
header("Content-Type: application/pdf");
header("Content-Type:application/octet-stream");
header("Content-Type:application/download");
header("Content-Disposition:attachment;filename=".$m_strOutputPdfFileName);
header("Content-Transfer-Encoding:binary");
$objWriter->save("php://output"); 
}
?>

模板文件内容(附加常用操作)
<?php 
global $m_objPHPExcel; // 由外部文件定义
// 设置基本属性
$m_objPHPExcel->getProperties()->setCreator("Sun Star Data Center")
->setLastModifiedBy("Sun Star Data Center")
->setTitle("Microsoft Office Excel Document")
->setSubject("Test Data Report -- From Sunstar Data Center")
->setDescription("LD Test Data Report, Generate by Sunstar Data Center")
->setKeywords("sunstar ld report")
->setCategory("Test result file");
// 创建多个工作薄
$sheet1 = $m_objPHPExcel->createSheet();
$sheet2 = $m_objPHPExcel->createSheet();
// 通过操作索引即可操作对应的工作薄
// 只需设置要操作的工作簿索引为当前活动工作簿,如
// $m_objPHPExcel->setActiveSheetIndex(0);
// 设置第一个工作簿为活动工作簿
$m_objPHPExcel->setActiveSheetIndex(0);
// 设置活动工作簿名称
// 如果是中文一定要使用iconv函数转换编码
$m_objPHPExcel->getActiveSheet()->setTitle(iconv('gbk', 'utf-8', '测试工作簿'));
// 设置默认字体和大小
$m_objPHPExcel->getDefaultStyle()->getFont()->setName(iconv('gbk', 'utf-8', '宋体'));
$m_objPHPExcel->getDefaultStyle()->getFont()->setSize(10);
// 设置一列的宽度
$m_objPHPExcel->getActiveSheet()->getColumnDimension('A')->setWidth(15);
// 设置一行的高度
$m_objPHPExcel->getActiveSheet()->getRowDimension('6')->setRowHeight(30);
// 合并单元格
$m_objPHPExcel->getActiveSheet()->mergeCells('A1:P1');
// 定义一个样式,加粗,居中
$styleArray1 = array(
'font' => array(
'bold' => true,
'color'=>array(
'argb' => '00000000',
),
),
'alignment' => array(
'horizontal' => PHPExcel_Style_Alignment::HORIZONTAL_CENTER,
),
);
// 将样式应用于A1单元格
$m_objPHPExcel->getActiveSheet()->getStyle('A1')->applyFromArray($styleArray1);
// 设置单元格样式(黑色字体)
$m_objPHPExcel->getActiveSheet()->getStyle('H5')->getFont()->getColor()->setARGB(PHPExcel_Style_Color::COLOR_BLACK); // 黑色
// 设置单元格格式(背景)
$m_objPHPExcel->getActiveSheet()->getStyle('H5')->getFill()->getStartColor()->setARGB('00ff99cc'); // 将背景设置为浅粉色
// 设置单元格格式(数字格式)
$m_objPHPExcel->getActiveSheet()->getStyle('F1')->getNumberFormat()->setFormatCode('0.000');
// 给特定单元格中写入内容
$m_objPHPExcel->getActiveSheet()->setCellValue('A1', 'Hello Baby');
// 设置单元格样式(居中)
$m_objPHPExcel->getActiveSheet()->getStyle('H5')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
// 给单元格中放入图片, 将数据图片放在J1单元格内
$objDrawing = new PHPExcel_Worksheet_Drawing();
$objDrawing->setName('Logo');
$objDrawing->setDescription('Logo');
$objDrawing->setPath("../logo.jpg"); // 图片路径,只能是相对路径
$objDrawing->setWidth(400); // 图片宽度
$objDrawing->setHeight(123); // 图片高度
$objDrawing->setCoordinates('J1');//单元格
$objDrawing->setWorksheet($m_objPHPExcel->getActiveSheet());
// 设置A5单元格内容并增加超链接
$m_objPHPExcel->getActiveSheet()->setCellValue('A5', iconv('gbk', 'utf-8', '超链接keiyi.com'));
$m_objPHPExcel->getActiveSheet()->getCell('A5')->getHyperlink()->setUrl('http://www.keiyi.com/');
?>

在服务器端生成静态文件
相比直接生成,这两种方法的主要区别是生成格式的不同,模板文件完全相同,下边是一个在上例基础上更改后的样子,注意与上例的区别。
<?php 
// 包含class的基本头文件
include("./class/class.php");
// 生成excel的基本类定义(注意文件名的大小写)
include("./class/phpexcel/PHPExcel.php");
// 包含写Excel5格式的文件,如果需要生成excel2007的文件,包含对应的Writer即可
include("./class/phpexcel/PHPExcel/Writer/Excel5.php");
// 包含写PDF格式文件
include("./class/phpexcel/PHPExcel/Writer/PDF.php");
// 创建phpexcel对象,此对象包含输出的内容及格式
$m_objPHPExcel = new PHPExcel();
// 模板文件,为了实现格式与内容分离,有关输出文件具体内容实现在模板文件中
// 模板文件将对象$m_objPHPExcel进行操作
include("./include/excel.php");
// 输出文件的类型,excel或pdf
$m_exportType = "pdf";
$m_strOutputExcelFileName = date('Y-m-j_H_i_s').".xls"; // 输出EXCEL文件名
$m_strOutputPdfFileName = date('Y-m-j_H_i_s').".pdf"; // 输出PDF文件名
// 输出文件保存路径,此路径必须可写
$m_strOutputPath = "./output/";
// 如果需要输出EXCEL格式
if($m_exportType=="excel"){
$objWriter = new PHPExcel_Writer_Excel5($m_objPHPExcel);
$objWriter->save($m_strOutputPath.$m_strOutputExcelFileName); 
}
// 如果需要输出PDF格式
if($m_exportType=="pdf"){
$objWriter = new PHPExcel_Writer_PDF($m_objPHPExcel);
$objWriter->save($m_strOutputPath.$m_strOutputPdfFileName); 
}
?>

PHP 相关文章推荐
使用数据库保存session的方法
Oct 09 PHP
图片存储与浏览一例(Linux+Apache+PHP+MySQL)
Oct 09 PHP
Zend 输出产生XML解析错误
Mar 03 PHP
php表单转换textarea换行符的方法
Sep 10 PHP
让PHP以ROOT权限执行系统命令的方法
Feb 10 PHP
非常精妙的PHP递归调用与静态变量使用
Dec 16 PHP
php使用array_rand()函数从数组中随机选择一个或多个元素
Apr 28 PHP
destoon实现资讯信息前面调用它所属分类的方法
Jul 15 PHP
PHP实现货币换算的方法
Nov 29 PHP
php实现格式化多行文本为Js可用格式
Apr 15 PHP
PHP使用socket发送HTTP请求的方法
Feb 14 PHP
PHP中大括号'{}'用法实例总结
Feb 08 PHP
PHP Cookie的使用教程详解
Jun 03 #PHP
PHP register_shutdown_function函数的深入解析
Jun 03 #PHP
深入PHP与浏览器缓存的分析
Jun 03 #PHP
PHP判断图片格式的七种方法小结
Jun 03 #PHP
基于session_unset与session_destroy的区别详解
Jun 03 #PHP
PHP批量采集下载美女图片的实现代码
Jun 03 #PHP
基于PHP CURL获取邮箱地址的详解
Jun 03 #PHP
You might like
PHP 编写的 25个游戏脚本
2009/05/11 PHP
PHP的邮件群发系统phplist配置方法详细总结
2016/03/30 PHP
Yii框架学习笔记之应用组件操作示例
2019/11/13 PHP
一个加密JavaScript的开源工具PACKER2.0.2
2006/11/04 Javascript
用正则xmlHttp实现的偷(转)
2007/01/22 Javascript
Javascript图像处理—为矩阵添加常用方法
2012/12/27 Javascript
JS中获取数据库中的值的方法
2013/07/14 Javascript
在JavaScript中使用timer示例
2014/05/08 Javascript
Nodejs学习笔记之NET模块
2015/01/13 NodeJs
AspNet中使用JQuery boxy插件的确认框
2015/05/20 Javascript
JavaScript中setUTCFullYear()方法的使用简介
2015/06/12 Javascript
JavaScript常用本地对象小结
2016/03/28 Javascript
微信小程序 云开发模糊查询实现解析
2019/09/02 Javascript
Jquery让form表单异步提交代码实现
2019/11/14 jQuery
vue 动态组件用法示例小结
2020/03/06 Javascript
让IDE识别webpack的别名alias的实现方法
2020/05/06 Javascript
Python中__new__与__init__方法的区别详解
2015/05/04 Python
Django 前后台的数据传递的方法
2017/08/08 Python
PyQt5每天必学之带有标签的复选框
2018/04/19 Python
Mac下Anaconda的安装和使用教程
2018/11/29 Python
将string类型的数据类型转换为spark rdd时报错的解决方法
2019/02/18 Python
Python实现bilibili时间长度查询的示例代码
2020/01/14 Python
python实现学生管理系统开发
2020/07/24 Python
CSS3中的5个有趣的新技术
2009/04/02 HTML / CSS
Bibloo奥地利:购买女装、男装、童装、鞋和配件
2018/10/18 全球购物
搞笑的获奖感言
2014/08/16 职场文书
励志演讲稿3分钟
2014/08/21 职场文书
三严三实对照检查材料范文
2014/09/23 职场文书
2014年师德师风自我剖析材料
2014/09/27 职场文书
党的群众路线教育实践活动先进个人材料
2014/12/24 职场文书
收银员岗位职责
2015/02/03 职场文书
2015年清明节扫墓演讲稿
2015/03/18 职场文书
首次购房证明
2015/06/19 职场文书
2016年推广普通话宣传周活动总结
2016/04/06 职场文书
进行数据处理的6个 Python 代码块分享
2022/04/06 Python
MySQL事务操作的四大特性以及并发事务问题
2022/04/12 MySQL