2

PHPEXEL で XLS を作成するときにメモリの使用を減らす方法があるかどうかを知る必要があります。これらのファイルには 15000 行ほどあります。

私はこのスクリプトを持っています:

    $payroll_incomes = $payroll_incomes->execute(null, Doctrine::HYDRATE_ARRAY);
$objPHPExcel->getActiveSheet()->fromArray($payroll_incomes[0], null, 'A1');

// Rename worksheet

$objPHPExcel->getActiveSheet()->setTitle('INGRESOS');

// Set active sheet index to the first sheet, so Excel opens this as the first sheet

$objPHPExcel->setActiveSheetIndex(0);



// Redirect output to a client’s web browser (Excel5)

header('Content-Type: application/vnd.ms-excel');

header('Content-Disposition: attachment;filename="Ingresos.xls"');

header('Cache-Control: max-age=0');



$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');

$objWriter->save('php://output')

このスクリプトを実行すると、このメッセージが表示されます

Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 20 bytes) in /var/www/payroll/plugins/sfPhpExcelPlugin/lib/PHPExcel/PHPExcel/Worksheet.php on line 962

ありがとう!!

アップデート

次のコード行を追加しました。

$cacheMethod = PHPExcel_CachedObjectStorageFactory::cache_to_phpTemp;

$cacheSettings = array( ' memoryCacheSize ' => '10KB');

PHPExcel_Settings::setCacheStorageMethod($cacheMethod, $cacheSettings);



$objPHPExcel = new PHPExcel();

だから、それは優れた仕事です:)

4

1 に答える 1

3

まず、セル キャッシュについて説明している PHPExcel ドキュメントのセクションを見てください。これは、より大きなスプレッドシートを操作するときに PHPExcel のメモリ要件を削減する方法であり、まさにこの目的のために実装されました。

于 2012-11-30T07:24:35.360 に答える