ホームページ >バックエンド開発 >PHPチュートリアル >大きな XLSX ファイルをロードするときに PHPExcel のメモリ使用量を最適化するにはどうすればよいですか?

大きな XLSX ファイルをロードするときに PHPExcel のメモリ使用量を最適化するにはどうすればよいですか?

Susan Sarandon
Susan Sarandonオリジナル
2024-11-25 11:13:10202ブラウズ

How Can I Optimize PHPExcel's Memory Usage When Loading Large XLSX Files?

PHPExcel のメモリ消費

XSLX テーブルのファイル サイズ (3MB) が一見大きいにもかかわらず、PHPExcel は次の理由によりテーブルをロードできません。メモリが不足しています。この問題は、PHPExcel がスプレッドシート データに採用する「メモリ内」表現が原因で発生し、PHP のメモリ制限の影響を受けやすくなっています。

メモリ使用量に影響を与える要素

物理ファイル サイズスプレッドシート内のセルの数 (行 x 列) と比較すると無関係です。経験則として、セルごとに約 1k のメモリが必要です。したがって、5M セルのワークブックには約 5 GB のメモリが必要になります。

メモリ最適化手法

メモリ使用量を最適化するには、次のような手法を使用できます。

1.ワークシートの制限:

複数のワークシートが存在するが、すべてが必要なわけではない場合は、setLoadSheetsOnly() メソッドを使用して、ロードするワークシートを指定します。

2.読み取りフィルターの使用:

PHPExcel_Reader_IReadFilter を実装する読み取りフィルター クラスを定義して、対象の特定のセルのみを読み取り、メモリ フットプリントを削減します。

3.チャンク読み取り:

読み取りフィルターを使用して一度に 1 つのチャンクだけがメモリに読み込まれるように、ワークブックを「チャンク」で読み取ります。

4. Set readDataOnly:

このオプションを有効にすると、書式設定情報を無視してセル値のみがロードされ、メモリ消費量を大幅に削減できます。

5.セルのキャッシュ:

セルごとに必要なメモリを最小限に抑えるために、セル オブジェクトを圧縮形式で保存するか、PHP のメモリの外に保存します。

コードの潜在的な問題

これらの最適化手法に加えて、コード内でのイテレータの使用に注目する価値があります。 効率的。代わりに、PHPExcel が提供する toArray() メソッドまたは rangeToArray() メソッドを使用してセル データの配列を取得することを検討してください。

以上が大きな XLSX ファイルをロードするときに PHPExcel のメモリ使用量を最適化するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。