Home >php教程 >php手册 >PHPExcel:用于Excel等文档生成的PHP开源类库

PHPExcel:用于Excel等文档生成的PHP开源类库

WBOY
WBOYOriginal
2016-06-06 19:59:101393browse

PHPExcel是一个十分强大的文档生成PHP开源类库,它不仅支持生成Excel(.xls)、Excel2007(.xlsx)文档,同时也支持PDF、HTML、CSV文档的生成。此外,PHPExcel还支持以现有的Excel文档为模板填充数据生成新的以上文档。并且,其本身的API文档和示例demo相当

PHPExcel是一个十分强大的文档生成PHP开源类库,它不仅支持生成Excel(.xls)、Excel2007(.xlsx)文档,同时也支持PDF、HTML、CSV文档的生成。此外,PHPExcel还支持以现有的Excel文档为模板填充数据生成新的以上文档。并且,其本身的API文档和示例demo相当完整,非常有助于开发人员使用。

 

PHPExcel的官方网站如下:

http://phpexcel.codeplex.com/

 

当前的版本是1.7.6,下载解压后的PHPExcel的目录结构如下所示:

PHPExcel:用于Excel等文档生成的PHP开源类库

其中:

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 // 导入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)

输出文档时,文件的扩展名必须与该参数字符串相契合。


参考资料:http://apps.hi.baidu.com/share/detail/35261920

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Previous article:PHP NavigatorNext article:debian(wheezy)安装rabbitMQ,php