PHPExcel:"无法读取文件"错误将Excel转换为PDF(.xlsx到.pdf)

Ema*_*rsa 5 php pdf xlsx phpexcel

我有一个只有一个电子表格的xlsx.我使用PHPExcel通过以下代码将其转换为pdf:

        error_reporting(E_ALL);
        date_default_timezone_set('Europe/London');
        require_once 'phpExcel/PHPExcel/IOFactory.php';
        require_once 'phpExcel/PHPExcel.php';

        $inputFileName = 'doc/ModUnico';
        $excel2 = PHPExcel_IOFactory::createReader('Excel2007');
        $excel2 = $excel2->load($inputFileName.'.xlsx');
        $excel2->setActiveSheetIndex(0);
        $excel2->getActiveSheet()->setCellValue('H5', '4');
        $objWriter = PHPExcel_IOFactory::createWriter($excel2, 'Excel2007');
        $objWriter->save($inputFileName.'_.xlsx');


        $objPHPexcel = PHPExcel_IOFactory::load($inputFileName.'_.xlsx');
        header('Content-Type: application/pdf');
        header('Content-Disposition: attachment;filename="test.pdf"');
        header('Cache-Control: max-age=0');

        $objWriter = PHPExcel_IOFactory::createWriter($objPHPexcel, 'PDF');
        $objWriter->writeAllSheets();
        $objWriter->setPreCalculateFormulas(false);
        $objWriter->save('php://output');
Run Code Online (Sandbox Code Playgroud)

问题是,当我尝试打开返回的文件时,我收到错误消息"无法读取文件".

EIDT:Renderer补充道

        $rendererName = PHPExcel_Settings::PDF_RENDERER_MPDF;
        $rendererLibrary = 'mpdf.php';
        $rendererLibraryPath = dirname(__FILE__).'/MPDF57/' . $rendererLibrary;


        if (!PHPExcel_Settings::setPdfRenderer(
            $rendererName,
            $rendererLibraryPath
            )) {
                die(
                    'NOTICE: Please set the $rendererName and $rendererLibraryPath values' .
                    '<br />' .
                    'at the top of this script as appropriate for your directory structure'
                );
        }
Run Code Online (Sandbox Code Playgroud)

Joe*_*vak 1

我认为马克说对了。当我遇到这样的错误时,我会从上往下开始。即中间 xlsx 文件是否正确?

我可能还会使用非常简单的 xls 文件或使用 PHPExcel 库的 csv 文件编写一些测试代码,当您尝试让这些文件正常工作时,您应该找出问题所在。与 pdf 渲染器相同,我会尝试一种不同的渲染器(如果有的话)。

乔伊