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的目录结构如下所示:
其中:
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
-
??
[php]
view plain
copy
-
<?php??
-
??
-
require_once
(
"Classes/PHPExcel.php"
);??
-
??
-
??
-
??
-
$phpexcel
?=?
new
?PHPExcel();??
-
??
-
??
-
$phpexcel
?=?PHPExcel_IOFactory::createReader(
"Excel5"
)->load(
"template.xls"
);??
-
??
-
?
-
?
-
?
-
??
-
??
-
$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"
);?
??
-
????????????????????????????
-
??
-
??
-
$phpexcel
->createSheet(1);??
-
??
-
??
-
$sheet
?=?
$phpexcel
->getSheet(1);??
-
??
-
??
-
$phpexcel
->setActiveSheetIndex(1);??
-
??
-
??
-
$sheet
?=?
$phpexcel
->getActiveSheet();??
-
??
-
??
-
??
-
$sheet
->setTitle(
"Test"
);??
-
??
-
??
-
$sheet
->setCellValue(
"A5"
,?
date
(
'Y-m-d?h:i:s'
));??
-
??
-
??
-
$sheet
->setCellValueByColumnAndRow(4,?3,?
date
(
'Y-m-d?h:i:s'
));??
-
??
-
??
-
$sheet
->getCell(
"A5"
)->getValue();??
-
??
-
??
-
$sheet
->mergeCells(
"C3:G6"
);??
-
??
-
??
-
$sheet
->unmergeCells(
"C3:G6"
);??
-
??
-
??
-
$sheet
->getRowDimension(3)->setRowHeight(100)?
??
-
??????????????????????????->setVisible(true)?
??
-
??????????????????????????->setRowIndex(6)?
??
-
??????????????????????????->setOutlineLevel(5);?
??
-
??
-
??
-
??
-
$sheet
->getColumnDimension(
"F"
)->setWidth(200)?
??
-
???????????????????????????????->setColumnIndex("I"
)?
??
-
???????????????????????????????->setVisible(false)?
??
-
???????????????????????????????->setAutoSize(true);?
??
-
??????????????
-
??
-
$sheet
->insertNewRowBefore(3,?1);??
-
??
-
??
-
$sheet
->insertNewColumnBefore(
"C"
,?1);?
??
-
$sheet
->insertNewColumnBeforeByIndex(2,?1);?
??
-
??
-
??
-
$style
?=?
$sheet
->getStyle(
"D3"
);?
??
-
??
-
??
-
$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)
输出文档时,文件的扩展名必须与该参数字符串相契合。