求phpexcel处理大文件时内存占用过大的解决方案
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了求phpexcel处理大文件时内存占用过大的解决方案,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2306字,纯文字阅读大概需要4分钟。
内容图文
![求phpexcel处理大文件时内存占用过大的解决方案](/upload/InfoBanner/zyjiaocheng/201/366f49b477ee4213a361a1023d04bd7e.jpg)
PS:
1. 我使用的版本是1.76,设置过使用文件之类的参数,完全不起作用;
2. 小文件已调通
3. 上面已经提到了,不用再说调大内存限制了
处理excel代码如下:执行报错
Fatal error: Using $this when not in object context in E:\wamp\www\uploadify\PHPExcel.php on line 796
function parse_excel_file($filename)
{
$php_reader = new PHPExcel_Reader_Excel2007();
$php_reader = PHPExcel_IOFactory::createReaderForFile($filename);
$php_excel = $php_reader->load($filename);
$current_sheet = $php_excel->getSheet(0);
$all_column = $current_sheet->getHighestColumn();
$all_row = $current_sheet->getHighestRow();
$list = array();
for ($row_index = 2; $row_index <= $all_row; $row_index++)
{
$row_val = '';
for ($col_index = 'A'; $col_index <= $all_column; $col_index++)
{
$addr = $col_index . $row_index;
$cell = $current_sheet->getCell($addr)->getValue();
if ($cell instanceof PHPExcel_RichText)
{
$cell = $cell->__toString();
$row_val = $row_val . ',' . $cell;
}
array_push($list, $row_val);
}
PHPExcel::Destroy();
return $list;
}
phpexcel.php中增加代码如下:
public function Destroy() {
foreach($this->_workSheetCollection as $index => $dummy) {
$this->_workSheetCollection[$index]->Destroy();
$this->_workSheetCollection[$index] = null;
}
}
worksheet.php中增加代码如下:
public function Destroy() {
foreach($this->_cellCollection as $index => $dummy) {
$this->_cellCollection[$index] = null;
}
}
回复讨论(解决方案)
一次性导出多少条?
调用方式应该是:$php_excel ->Destroy();
phpexcel 库耗内存太严重 计算时全部在内存缓存
曾经ini_set('memory_limit','1024M');只能导出1W条数据
最后我们采用了csv 流式文件 世界清静了不少
调用方式应该是:$php_excel ->Destroy();
phpexcel 库耗内存太严重 计算时全部在内存缓存
曾经ini_set('memory_limit','1024M');只能导出1W条数据
最后我们采用了csv 流式文件 世界清静了不少
感谢提示,用了你的写法确实不报错了,但是内存没有destroy成功,还是在一次次增长,你说的csv是不用插件直接导出那种还是phpexcel的导出csv?我这里是读取
内容总结
以上是互联网集市为您收集整理的求phpexcel处理大文件时内存占用过大的解决方案全部内容,希望文章能够帮你解决求phpexcel处理大文件时内存占用过大的解决方案所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。