PHP高性能Excel扩展1.2.8发布,文件读取数据类型可控!-php教程

资源魔 31 0

为何应用 xlswriter

xlswriter 是一个 PHP C 扩大,可用于正在 Excel 2007+ XLSX 文件中读取数据,拔出多个工作表,写入文本、数字、公式、日期、图表、图片以及超链接。

请参考下方比照图;因为内存缘由,PHPExcel 与 PHPSpreadSheet 正在数据量 绝对较年夜 的状况下无奈失常工作,尽管能够经过 修正memory_limit 设置装备摆设来处理内存成绩,但实现工作的工夫可能会更长;

31b9a2aecf623a68e8037fc71e81f0f.png

它支持如下性能:

1、写入

● 100%兼容的 Excel XLSX 文件

● 完好的 Excel 格局

● 兼并单位格

● 界说工作表称号

● 过滤器

● 图表

● 数据验证以及下拉列表

● 工作表 PNG/JPEG 图象

● 用于写入年夜文件的内存优化模式

● 实用于 Linux,FreeBSD,OpenBSD,OS X,Windows

● 编译为 32 位以及 64 位

● FreeBSD 答应证

● 惟一的依赖是 zlib

2、读取

● 完好读取数据

● 光标读取数据

● 按数据类型读取

1.2.8 新特点

一、新增日期写入

$config = [
    'path' => './tests'
];
$fileObject = new \Vtiful\Kernel\Excel($config);
$fileObject = $fileObject->fileName('tutorial.xlsx');
$filePath = $fileObject->header(['date'])
    ->insertDate(1, 0, time(), '妹妹m d yyyy hh:妹妹 AM/PM')
    ->output();

二、新增自界说单位格数据类型读取

$config = [
    'path' => './tests',
];
$fileObject = new \Vtiful\Kernel\Excel($config);
$fileObject->openFile('tutorial.xlsx')
    ->openSheet();
var_dump($fileObject->nextRow([
    \Vtiful\Kernel\Excel::TYPE_STRING,
    \Vtiful\Kernel\Excel::TYPE_TIMESTAMP,
]));

基准测试

测试环境:

Macbook Pro 13 inch
Intel Core i5
16GB 2133MHz LPDDR3 Memory
128GB SSD Storage.

导出

两种内存模式,导出 100W 行数据,单行 27 列,每一个单位格 19 个中文字符

● 惯例模式:耗时 29S,内存占用 2083MB;

● 固定内存模式:耗时 52S, 内存占用 <1MB;

读取

读取 100W 行数据,每一行 1 列,单位格数据为 int

● 全量读取:耗时 3S, 内存占用 558MB;

● 游标读取:耗时 2.8S, 内存占用 <1MB;

仓库地点

Github:https://github.com/viest/php-ext-excel-export

Gitee:https://gitee.com/viest/php-ext-xlswriter

PECL:https://pecl.php.net/package/xlswriter

文档

https://xlswriter-docs.viest.me

End

最初的最初请没有要遗记 star

更多PHP常识,请拜访PHP中文网PHP教程

以上就是PHP高功能Excel扩大1.2.8公布,文件读取数据类型可控!的具体内容,更多请存眷资源魔其它相干文章!

标签: php php开发教程 php开发资料 php开发自学

抱歉,评论功能暂时关闭!