This topic created in 3469 days ago, the information mentioned may be changed or developed.
现在有个需求,必须输出 xls 或 xlsx 因为 csv 没有样式。
PHPexcel 这个东西的最大弱点,在于它写入一个 excel 文件之前,必须把这个文件读入内存,不能像写文本那样,简单的续写就行了,则就导致这玩意处理不了大文件,当一个文件本身就很大的时候,载入就要花很长时间。因为内容的列非常多,而且样式复杂,所以大约在 10000 行的时候内存就要爆炸。爆炸还是其次,关键是分批写入随着文件越来越大会变得越来越慢
16 replies • 2016-11-18 13:45:01 +08:00
 |
|
2
R18 Nov 16, 2016 via Android
我记得可以设置缓存区
|
 |
|
4
demoxu Nov 16, 2016
phpexcel 我记得能设置硬盘缓存来替代默认的内存缓存;然而好久不用,不知道设置了。上 github 找找吧
|
 |
|
5
shoaly Nov 16, 2016
可以折中一下, 用 php 写入到数据库, 另外找个 python 从数据库读取 写到 excel 里面去
|
 |
|
7
fzxml Nov 16, 2016
用 python 吧
|
 |
|
9
oisc Nov 16, 2016
可以通过 Excel Driver 用 ODBC 的方式读写 xls 、 xlsx 文件,不过你需要 专门一台 Windows 来做 ODBC 源。
|
 |
|
10
mhycy Nov 16, 2016
XLS 是结构化数据,在对象生成的过程中必定需要耗费大量的内存存放数据,最后再输出成 XLS 文件 建议加内存,能简单用硬件解决的问题不应增加程序复杂度
|
 |
|
11
Arnie97 Nov 16, 2016 via Android
如果 Excel 本身不存在这个问题,你可以装个 Excel ,然后通过 COM / ODBC 之类调用。
|
 |
|
12
yasin Nov 16, 2016
没什么好的办法,我们后来改成 nodejs 处理这种任务。 6 万条数据 10 秒内导出。
|
 |
|
13
lygmqkl Nov 16, 2016 via iPhone
phpcli 或者 python 异步完成即可
|
 |
|
15
crossmaya Nov 17, 2016
可以设置内存缓冲区,使用硬盘,但是速度尼玛贼慢!我现在是 php 生成 json 文件然后使用 python 来做。
|
 |
|
16
Patrick95 Nov 18, 2016
PHPExcel_CachedObjectStorageFactory::cache_to_discISAM;
缓存到磁盘。
|