设为首页 收藏本站
查看: 677|回复: 0

[经验分享] PHPExcel:用于Excel等文档生成的PHP开源类库

[复制链接]

尚未签到

发表于 2017-4-8 13:34:39 | 显示全部楼层 |阅读模式
  http://blog.csdn.net/for023/article/details/7951307
  PHPExcel是一个十分强大的文档生成PHP开源类库,它不仅支持生成Excel(.xls)、Excel2007(.xlsx)文档,同时也支持PDF、HTML、CSV文档的生成。此外,PHPExcel还支持以现有的Excel文档为模板填充数据生成新的以上文档。并且,其本身的API文档和示例demo相当完整,非常有助于开发人员使用。
  PHPExcel的官方网站如下:
  http://phpexcel.codeplex.com/
  当前的版本是1.7.6,下载解压后的PHPExcel的目录结构如下所示:
DSC0000.jpg

  其中:
  Classes目录下是PHPExcel的源代码文件:PHPExcel.php文件是类库的接口,外部的PHP代码通过它来实现对PHPExcel的调用;PHPExcel目录下是各种不同文档(如Excel、Excel2007、PDF等)的读取和生成的具体操作代码,它们由Classes目录下的PHPExcel.php文件通过工厂模式统一进行调用。
  Documentation目录下是PHPExcel的官方帮助文档,尤其是API目录下网页文件全部是PHPExcel的API帮助文档,而其它的则是对这个开源项目的介绍。
  Tests目录下是PHPExcel的将近40个示例小程序,可以与Classes目录一同放到Apache+PHP环境下进行测试与学习。
  下面是PHPExcel中一些常用的代码段:
[php]view plaincopy


  •   

[php]view plaincopy


  • <?php  
  • // 导入PHPExcel类库  
  • require_once("Classes/PHPExcel.php");  
  •   
  • // 通常PHPExcel对象有两种实例化的方式  
  • // 1. 通过new关键字创建空白文档  
  • $phpexcel = new PHPExcel();  
  •   
  • // 2. 通过读取已有的模板创建  
  • $phpexcel = PHPExcel_IOFactory::createReader("Excel5")->load("template.xls");  
  •   
  • /** 
  •  * 实例化之后的PHPExcel对象类似于一个暂存于内存中文档文件, 
  •  * 可以对它进行操作以达到修改文档数据的目的 
  •  */  
  • // 设置文档属性  
  • $phpexcel->getProperties()->setCreator("Liu Jian") // 文档作者  
  •                           ->setLastModifiedBy("Liu Jian") // 最后一次修改者  
  •                           ->setTitle("Office 2003 XLS Test Document") // 标题  
  •                           ->setSubject("Office 2003 XLS Test Document") // 主题  
  •                           ->setDescription("Test document for Office 2003 XLS, generated using PHPExcel.") // 备注  
  •                           ->setKeywords("office 2003 openxml php") // 关键字  
  •                           ->setCategory("Test result file"); // 类别  
  •                             
  • // 默认状态下,新创建的空白文档(通过new)只有一个工作表(sheet),且它的编号(index)为0  
  • // 可以通过如下的方式添加新的工作表  
  • $phpexcel->createSheet(1);  
  •   
  • // 获取已有编号的工作表  
  • $sheet = $phpexcel->getSheet(1);  
  •   
  • // 设置当前激活的工作表编号  
  • $phpexcel->setActiveSheetIndex(1);  
  •   
  • // 获取当前激活的工作表  
  • $sheet = $phpexcel->getActiveSheet();  
  •   
  • // 得到工作表之后就可以操作它的单元格以修改数据了  
  • // 修改工作表的名称  
  • $sheet->setTitle("Test");  
  •   
  • // 设置单元格A5的值  
  • $sheet->setCellValue("A5", date('Y-m-d h:i:s'));  
  •   
  • // 设置第3行第5列(E3)的值  
  • $sheet->setCellValueByColumnAndRow(4, 3, date('Y-m-d h:i:s'));  
  •   
  • // 获取单元格A5的值  
  • $sheet->getCell("A5")->getValue();  
  •   
  • // 合并单元格  
  • $sheet->mergeCells("C3:G6");  
  •   
  • // 拆分合并的单元格  
  • $sheet->unmergeCells("C3:G6");  
  •   
  • // 设置第3行的属性  
  • $sheet->getRowDimension(3)->setRowHeight(100) // 行高  
  •                           ->setVisible(true) // 是否可见,默认为true  
  •                           ->setRowIndex(6) // 变更行号为6  
  •                           ->setOutlineLevel(5); // 优先级别,默认为0,参数必须是0到7  
  •   
  • // 设置第F列的属性  
  • // getColumnDimension("F")可以用getColumnDimensionByColumn(5)代替  
  • $sheet->getColumnDimension("F")->setWidth(200) // 列宽  
  •                                ->setColumnIndex("I") // 变更列号为I  
  •                                ->setVisible(false) // 是否可见  
  •                                ->setAutoSize(true); // 自动适应列宽  
  •               
  • // 在第3行前面插入1行,该行将变成新的第3行,其它的依次下移1行  
  • $sheet->insertNewRowBefore(3, 1);  
  •   
  • // 在第C行前面插入1列,该列将变成新的第C列,其它的依次右移1列  
  • $sheet->insertNewColumnBefore("C", 1); // 方法一  
  • $sheet->insertNewColumnBeforeByIndex(2, 1); // 方法二,第C列又是第2列  
  •   
  • // 获取单元格D3的样式对象  
  • $style = $sheet->getStyle("D3"); // 等价于getStyleByColumnAndRow(3, 3)  
  •   
  • // 设置该单元格的字体属性  
  • $style->getFont()->setBold(true) // 是否粗体  
  •                  ->setSize(16) // 字号  
  •                  ->setName("Gungsuh") // 字体名,只适用于外文字体  
  •                  ->setItalic(true) // 是否斜体  
  •                  ->setStrikethrough(true) // 是否有删除线  
  •                  ->setUnderline(PHPExcel_Style_Font::UNDERLINE_DOUBLEACCOUNTING) // 下划线类型  
  •                  ->getColor()->setARGB(PHPExcel_Style_Color::COLOR_BLUE); // 字体颜色  
  •                   
  • // 设置该单元格的背景填充属性  
  • $style->getFill()->setFillType(PHPExcel_Style_Fill::FILL_SOLID) // 填充模式  
  •                  ->getStartColor()->setARGB(PHPExcel_Style_Color::COLOR_YELLOW); // 背景颜色  
  •   
  • // 设置该单元格中数字的格式  
  • $style->getNumberFormat()->setFormatCode("0.00");  
  •   
  • // 设置该单元格中文本对齐方式  
  • $style->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER) // 水平方向  
  •                       ->setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER); // 垂直方向  
  •   
  • $sheet->setCellValue("D3", "12.3456");  
  •   
  • // 在本地保存文档  
  • PHPExcel_IOFactory::createWriter($phpexcel, 'Excel5')->save("output.xls");  
  •   
  • // 输出文档到页面  
  • header('Content-Type: application/vnd.ms-excel');  
  • header('Content-Disposition: attachment;filename="test.xls"');  
  • header('Cache-Control: max-age=0');  
  • PHPExcel_IOFactory::createWriter($phpexcel, 'Excel5')->save('php://output');  
  • ?>  

  需要注意的是:
  1. PHPExcel本身具有在单元格中插入图片以及设置单元格边框的相关函数,但是个人感觉动态添加图片、设置边框远没有使用静态的excel模版来生成文档更好用。实在需要的情况下可以参见最后的参考资料。
  2.添加新的行或列时,新的行或列的样式(style)会自动与新行/列的前一行/列保持一致。
  3.设置单元格填充颜色时,必须先设定填充模式,否则会失效。
  4.通过PHPExcel_IOFactory的静态方法createReader或createWriter,必须传入文档格式所对应的参数字符串,其中:

  • Excel5对应Excel 2003(.xls)
  • Excel2007对应Excel 2007(.xlsx)
  • PDF对应PDF(.pdf)
  • CSV对应CSV(.csv)
  输出文档时,文件的扩展名必须与该参数字符串相契合。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-362029-1-1.html 上篇帖子: 使用PHP的SPL,跟效率和工资相关 下篇帖子: PHP类继承实例: 高中学生 -- 学生--人
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表