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 サイトの他の関連記事を参照してください。