PHP_XLSXWriter
PHP_XLSXWriter 0.39
该库被设计为轻量级的,并且具有最少的内存使用量。
它旨在以 (Office 2007+) xlsx 格式输出 Excel 兼容的电子表格,仅支持基本功能:
PHPExcel 再也不会出现内存不足的情况。
简单的 PHP CLI 示例:
$ data = array (
array ( ' year ' , ' month ' , ' amount ' ),
array ( ' 2003 ' , ' 1 ' , ' 220 ' ),
array ( ' 2003 ' , ' 2 ' , ' 153.5 ' ),
);
$ writer = new XLSXWriter ();
$ writer -> writeSheet ( $ data );
$ writer -> writeToFile ( ' output.xlsx ' );
简单/高级单元格格式:
$ header = array (
' created ' => ' date ' ,
' product_id ' => ' integer ' ,
' quantity ' => ' #,##0 ' ,
' amount ' => ' price ' ,
' description ' => ' string ' ,
' tax ' => ' [$$-1009]#,##0.00;[RED]-[$$-1009]#,##0.00 ' ,
);
$ data = array (
array ( ' 2015-01-01 ' , 873 , 1 , ' 44.00 ' , ' misc ' , ' =D2*0.05 ' ),
array ( ' 2015-01-12 ' , 324 , 2 , ' 88.00 ' , ' none ' , ' =D3*0.05 ' ),
);
$ writer = new XLSXWriter ();
$ writer -> writeSheetHeader ( ' Sheet1 ' , $ header );
foreach ( $ data as $ row )
$ writer -> writeSheetRow ( ' Sheet1 ' , $ row );
$ writer -> writeToFile ( ' example.xlsx ' );
50000行:(1.4s,0MB内存使用)
include_once ( " xlsxwriter.class.php " );
$ writer = new XLSXWriter ();
$ writer -> writeSheetHeader ( ' Sheet1 ' , array ( ' c1 ' => ' integer ' , ' c2 ' => ' integer ' , ' c3 ' => ' integer ' , ' c4 ' => ' integer ' ) );
for ( $ i = 0 ; $ i < 50000 ; $ i ++)
{
$ writer -> writeSheetRow ( ' Sheet1 ' , array ( $ i , $ i + 1 , $ i + 2 , $ i + 3 ) );
}
$ writer -> writeToFile ( ' huge.xlsx ' );
echo ' # ' . floor (( memory_get_peak_usage ())/ 1024 / 1024 ). " MB " . "n" ;
行 | 时间 | 记忆 |
---|---|---|
50000 | 1.4秒 | 0MB |
100000 | 2.7秒 | 0MB |
150000 | 4.1秒 | 0MB |
200000 | 5.7秒 | 0MB |
250000 | 7.0秒 | 0MB |
简单的单元格格式映射到更高级的单元格格式
简单的格式 | 格式代码 |
---|---|
细绳 | @ |
整数 | 0 |
日期 | 年-月-日 |
日期时间 | 年-月-日 时:分:秒 |
时间 | 时:分:秒 |
价格 | #,##0.00 |
美元 | [$$-1009]#,##0.00;[红色]-[$$-1009]#,##0.00 |
欧元 | #,##0.00 [$€-407];[红色]-#,##0.00 [$€-407] |
从 0.30 版本开始就提供了基本的单元格样式
风格 | 允许值 |
---|---|
字体 | Arial、Times New Roman、Courier New、Comic Sans MS |
字体大小 | 8,9,10,11,12 ... |
字体样式 | 粗体、斜体、下划线、删除线或多个即:“粗体、斜体” |
边界 | 左、右、上、下或多个,即:“上、左” |
边框式 | 薄、中、厚、dashDot、dashDotDot、虚线、虚线、双、头发、mediumDashDot、mediumDashDotDot、mediumDashed、slantDashDot |
边框颜色 | #RRGGBB,即:#ff99cc 或 #f9c |
颜色 | #RRGGBB,即:#ff99cc 或 #f9c |
充满 | #RRGGBB,即:#eeffee 或 #efe |
哈利恩 | 一般、左、右、对齐、居中 |
瓦利尼 | 底部、中心、分布 |