PHPExcel 中的内存消耗
尽管 XSLX 表的文件大小看似很大(3MB),但 PHPExcel 无法加载它,因为内存不足。此问题源于 PHPExcel 对电子表格数据采用的“内存中”表示方式,使其容易受到 PHP 内存限制的影响。
影响内存使用的因素
物理文件大小与电子表格中的单元格数量(行 x 列)无关。根据经验,每个单元大约需要 1k 内存。因此,5M 单元工作簿将需要大约 5GB 内存。
内存优化技术
要优化内存使用,可以采用多种技术:
1.限制工作表:
如果存在多个工作表但不需要全部,请使用 setLoadSheetsOnly() 方法指定应加载哪些工作表。
2.使用读取过滤器:
定义一个实现 PHPExcel_Reader_IReadFilter 的读取过滤器类,以仅读取感兴趣的特定单元格,从而减少内存占用。
3.块读取:
以“块”的形式读取工作簿,以便使用读取过滤器一次仅将一个块加载到内存中。
4.设置readDataOnly:
启用此选项仅加载单元格值,忽略格式信息,这可以显着减少内存消耗。
5.单元格缓存:
以压缩格式存储单元格对象或将其存储在 PHP 内存之外,以最大限度地减少每个单元格所需的内存。
代码中的潜在问题
除了这些优化技术之外,值得注意的是在代码中使用迭代器,这可能会降低效率。相反,请考虑使用 PHPExcel 提供的 toArray() 或 rangeToArray() 方法来获取单元格数据数组。
以上是加载大型 XLSX 文件时如何优化 PHPExcel 的内存使用?的详细内容。更多信息请关注PHP中文网其他相关文章!