当前位置 : 李杰的流水账 > 技术 > linux

PHP操作Excel – PHPExcel 基本用法详解

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 plain copy
  1. <?php
  2. // 导入PHPExcel类库
  3. require_once("Classes/PHPExcel.php");
  4. // 通常PHPExcel对象有两种实例化的方式
  5. // 1. 通过new关键字创建空白文档
  6. $phpexcel = new PHPExcel();
  7. // 2. 通过读取已有的模板创建
  8. $phpexcel = PHPExcel_IOFactory::createReader("Excel5")->load("template.xls");
  9. /** 
  10.  * 实例化之后的PHPExcel对象类似于一个暂存于内存中文档文件, 
  11.  * 可以对它进行操作以达到修改文档数据的目的
  12.  */
  13. // 设置文档属性
  14. $phpexcel->getProperties()->setCreator("Liu Jian"// 文档作者
  15.                           ->setLastModifiedBy("Liu Jian"// 最后一次修改者
  16.                           ->setTitle("Office 2003 XLS Test Document"// 标题
  17.                           ->setSubject("Office 2003 XLS Test Document"// 主题
  18.                           ->setDescription("Test document for Office 2003 XLS, generated using PHPExcel."// 备注
  19.                           ->setKeywords("office 2003 openxml php"// 关键字
  20.                           ->setCategory("Test result file"); // 类别
  21. // 默认状态下,新创建的空白文档(通过new)只有一个工作表(sheet),且它的编号(index)为0
  22. // 可以通过如下的方式添加新的工作表
  23. $phpexcel->createSheet(1);
  24. // 获取已有编号的工作表
  25. $sheet = $phpexcel->getSheet(1);
  26. // 设置当前激活的工作表编号
  27. $phpexcel->setActiveSheetIndex(1);
  28. // 获取当前激活的工作表
  29. $sheet = $phpexcel->getActiveSheet();
  30. // 得到工作表之后就可以操作它的单元格以修改数据了
  31. // 修改工作表的名称
  32. $sheet->setTitle("Test");
  33. // 设置单元格A5的值
  34. $sheet->setCellValue("A5"date('Y-m-d h:i:s'));
  35. // 设置第3行第5列(E3)的值
  36. $sheet->setCellValueByColumnAndRow(4, 3, date('Y-m-d h:i:s'));
  37. // 获取单元格A5的值
  38. $sheet->getCell("A5")->getValue();
  39. // 合并单元格
  40. $sheet->mergeCells("C3:G6");
  41. // 拆分合并的单元格
  42. $sheet->unmergeCells("C3:G6");
  43. // 设置第3行的属性
  44. $sheet->getRowDimension(3)->setRowHeight(100) // 行高
  45.                           ->setVisible(true) // 是否可见,默认为true 
  46.                           ->setRowIndex(6) // 变更行号为6
  47.                           ->setOutlineLevel(5); // 优先级别,默认为0,参数必须是0到7
  48. // 设置第F列的属性
  49. // getColumnDimension("F")可以用getColumnDimensionByColumn(5)代替
  50. $sheet->getColumnDimension("F")->setWidth(200) // 列宽
  51.                                ->setColumnIndex("I"// 变更列号为I
  52.                                ->setVisible(false) // 是否可见
  53.                                ->setAutoSize(true); // 自动适应列宽
  54. // 在第3行前面插入1行,该行将变成新的第3行,其它的依次下移1行
  55. $sheet->insertNewRowBefore(3, 1);
  56. // 在第C行前面插入1列,该列将变成新的第C列,其它的依次右移1列
  57. $sheet->insertNewColumnBefore("C", 1); // 方法一
  58. $sheet->insertNewColumnBeforeByIndex(2, 1); // 方法二,第C列又是第2列
  59. // 获取单元格D3的样式对象
  60. $style = $sheet->getStyle("D3"); // 等价于getStyleByColumnAndRow(3, 3)
  61. // 设置该单元格的字体属性
  62. $style->getFont()->setBold(true) // 是否粗体
  63.                  ->setSize(16) // 字号
  64.                  ->setName("Gungsuh"// 字体名,只适用于外文字体
  65.                  ->setItalic(true) // 是否斜体
  66.                  ->setStrikethrough(true) // 是否有删除线
  67.                  ->setUnderline(PHPExcel_Style_Font::UNDERLINE_DOUBLEACCOUNTING) // 下划线类型
  68.                  ->getColor()->setARGB(PHPExcel_Style_Color::COLOR_BLUE); // 字体颜色
  69. // 设置该单元格的背景填充属性
  70. $style->getFill()->setFillType(PHPExcel_Style_Fill::FILL_SOLID) // 填充模式
  71.                  ->getStartColor()->setARGB(PHPExcel_Style_Color::COLOR_YELLOW); // 背景颜色
  72. // 设置该单元格中数字的格式
  73. $style->getNumberFormat()->setFormatCode("0.00");
  74. // 设置该单元格中文本对齐方式
  75. $style->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER) // 水平方向
  76.                       ->setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER); // 垂直方向
  77. $sheet->setCellValue("D3""12.3456");
  78. // 在本地保存文档
  79. PHPExcel_IOFactory::createWriter($phpexcel'Excel5')->save("output.xls");
  80. // 输出文档到页面
  81. header('Content-Type: application/vnd.ms-excel');
  82. header('Content-Disposition: attachment;filename="test.xls"');
  83. header('Cache-Control: max-age=0');
  84. PHPExcel_IOFactory::createWriter($phpexcel'Excel5')->save('php://output');
  85. ?>
  需要注意的是: 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)
输出文档时,文件的扩展名必须与该参数字符串相契合。

内容列表