首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > PHP >

PHPExcel解决内存占用过大有关问题-设置单元格对象缓存

2012-12-26 
PHPExcel解决内存占用过大问题-设置单元格对象缓存PHPExcel是一个很强大的处理Excel的PHP开源类,但是很大

PHPExcel解决内存占用过大问题-设置单元格对象缓存

PHPExcel是一个很强大的处理Excel的PHP开源类,但是很大的一个问题就是它占用内存太大,从1.7.3开始,它支持设置cell的缓存方式,但是推荐使用目前稳定的版本1.7.6,因为之前的版本都会不同程度的存在bug,以下是其官方文档:

?

$cacheMethod = PHPExcel_CachedObjectStorageFactory::cache_to_wincache;$cacheSettings = array( 'cacheTime' => 600 );PHPExcel_Settings::setCacheStorageMethod($cacheMethod, $cacheSettings);PHPExcel官方文档1.7.6 写道When your script terminates all entries will be cleared from Wincache, regardless of the cacheTime value, so it cannot be used for persistent storage using this mechanism.

?

?

呃,终于“又”写完了,之前写的一版,有的文字是直接从word粘过来的,带了一大堆格式,被截断了,悲了个剧的,翻译文档也不是件容易的事啊……PHPExcel还是比较强大的,最大的问题就是内存占用的问题,我之前用的1.7.2,还没有这种机制,导出2W+数据,占用了400M+内存,改成1.7.6,使用cach_to_diskISAM方式,内存降低到200M-,效果还是很明显的,不过依然还是够高的,excel文件5.1M,就使用了200M-和未知大小的磁盘空间,PHPExcel啥时候能出一个轻量级的版本,不需要那么多花哨的功能,只需要导出最普通的数据的版本就好了!

?

1 楼 loserwn 2011-07-01   1.  修改一下错别字:当脚本运行结束时,所有的数据都会从APC中清楚(忽略缓存时间),不能使用此机制作为持久缓存。

2. 我嚼着,Excel 作为M$的自有的文件格式,内部隐藏了太多的咚咚。PHPExcel能做到如此的兼容性已经实属不易了。尤其是在不依靠.NET或者各种COM+库的前提下。 200MB- 的memory花费还是值得的。 2 楼 silentime 2011-07-01   嗯,是啊,PHPExcel已经很强大了~~ 3 楼 yhg7752 2011-10-26   $cacheMethod = PHPExcel_CachedObjectStorageFactory:: cache_to_phpTemp;  
$cacheSettings = array( ' memoryCacheSize '  => '8MB' 
                      );  
PHPExcel_Settings::setCacheStorageMethod($cacheMethod, $cacheSettings); 
我用的是这中设置的,却只导出了10000条数据就不行了,我是想导出多个excel 一共160000条数据呢 每个excel中含有10000条数据  结果只导出了一个 4 楼 yhg7752 2011-10-26   不知道为什么,您能帮忙解决下吗? 谢谢了 5 楼 silentime 2011-10-30   yhg7752 写道不知道为什么,您能帮忙解决下吗? 谢谢了
看看占用内存的大小,windows用任务管理器,linux用top 6 楼 ashmodeus 2012-04-25   不错,基本上导出一个5000行的表格内存就上128M超出了。

热点排行