Ошибка загрузки листа Excel из базы данных с использованием Phpspreadsheet - PullRequest
0 голосов
/ 14 января 2019

Я пытаюсь получить записи из базы данных, а затем загрузить эти записи в виде таблицы Excel. Он загружается, но когда я открываю лист Excel, я вижу html-коды и некоторую тарабарщину. Я даже не вижу записи вообще. Я не знаю, откуда проблема. Вот мой php код:

use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PhpOffice\PhpSpreadsheet\Writer\Xlsx;

     $res = $call->fetchRecords();
        $num = $res->num_rows;

        if($num > 0){

            $spreadsheet = new Spreadsheet();
            $sheet = $spreadsheet->getActiveSheet();
            $sheet->setTitle('records');

            $i = 1;
            while($row = mysqli_fetch_assoc($res)){
                $sheet->setCellValue('A'.$i, $row['date']);
                $sheet->setCellValue('B'.$i, $row['Reference']);
                $sheet->setCellValue('C'.$i, $row['amount']);
                $i++;
            }

            $writer = new Xlsx($spreadsheet);
            if(isset($writer)){
                header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
                header('Content-Disposition: attachment;filename="pending_transactions.xlsx"');
                header('Cache-Control: max-age=0');
                header('Content-Transfer-Encoding: binary');
                header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT');
                header('Cache-Control: cache, must-revalidate');
                header('Pragma: public');
                $writer->save('php://output');
            }

        }
...