170 похожих чатов

Здравствуйте, подскажите кто работает с библиотекой PhpExcel.Делаем выгрузку товаров с

сайта, зависает при выгрузке 11тыс с чем-то полей(40 колонок). Вернее файл сохраняется, все поля присутствуют, работа кода зависает на строчке
$objWriter = new \PHPExcel_Writer_Excel2007($objPHPExcel);
$objWriter->save($_SERVER['DOCUMENT_ROOT'].$upload_file_path);
Если ограничить количество полей в два раза то всё выгружает нормально. Какие есть решения? Была идея разбивать файл на несколько частей и потом сохранять в один. Но тогда боюсь что та же самая проблема будет с зависанием при сохранении.
Код если нужно могу в личные сообщения скинуть, слишком много.

8 ответов

19 просмотров

Ну а падает как? По oom?

Наталья-Светлова Автор вопроса

посмотрите на это https://github.com/mk-j/PHP_XLSXWriter

Наталья Светлова
Не поняла вопроса

имелось ввиду нехватка оперативной памяти out of memory

Наталья Светлова
нет, 504 выдает спустя время.

отвалился по таймауту, сколько не увеличивайте время выполнения, сколько не выделяйте памяти, все равно упадет. Это старая известная проблема библиотеки которую вы используете. Чем больше строк и колонок, тем более медленнее выполняется и больше потребляет ресурсов. Меняйте либу.

Работайте с настоящим Excel вам ничто не поможет кроме него

Похожие вопросы

Обсуждают сегодня

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
Ребят в СИ можно реализовать ООП?
Николай
33
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
у вас два процесса. один посылает другому сигнал. у вас есть код обоих процессов? если всё не так - расскажите как оно на самом деле. а именно кто кому чего, есть-ли консоли,...
Karagy
6
Карта сайта