PHPExcel:下载电子表格

3

长期以来,我一直在尝试为用户提供使用对话框“另存为”或“打开”创建的电子表格的功能。

这是我尝试的内容,没有错误提示,只是屏幕上出现了乱码字符:

//CREATE SPEADSHEET

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

// We'll be outputting an excel file
header('Content-type: application/vnd.ms-excel');

// It will be called file.xls
header('Content-Disposition: attachment; filename="file.xls"');

// Write file to the browser
$objWriter->save('php://output');

我非常感激您能帮助我解决这个问题。


3
在设置标题之前,您是否有任何回显内容?您是否查看了在屏幕上用无意义字符显示的标题以确保它们是正确的? - Pitchinnate
@Mark Baker,我无法“另存为”,也没有收到任何错误提示,这就是问题所在。 - AnchovyLegend
谢谢回复。不,没有任何数据在头部之前被回显...你说的“你是否查看了屏幕上用乱码显示的头部以确保它们是正确的”是什么意思?抱歉,我对这一切都很新。 - AnchovyLegend
请查看您的浏览器返回的HTML头。 - Pitchinnate
谢谢你的帮助。那不是问题所在。我检查了,似乎没有什么问题。它仍然无法正常工作。 - AnchovyLegend
显示剩余4条评论
2个回答

5

我刚刚尝试了你的代码一部分,它完全可以运行。如果你得到的只是乱码,问题可能实际上出在生成表格的部分,请检查那个部分是否有任何错误。以下是我用来测试它的代码:

 define('EOL',(PHP_SAPI == 'cli') ? PHP_EOL : '<br />');

    /** Include PHPExcel */
    require_once '../../PHPExcel/Classes/PHPExcel.php';

    // Create new PHPExcel object
    $objPHPExcel = new PHPExcel();

    // Set document properties
    $objPHPExcel->getProperties()->setCreator("Lumina")
                         ->setLastModifiedBy("Lumina")
                         ->setTitle("Entry members")
                         ->setSubject("Entry members")
                         ->setDescription("List of members participting.")
                         ->setKeywords("office PHPExcel php")
                         ->setCategory("Entry members");

        // Add some data                 
        $objPHPExcel->setActiveSheetIndex(0)
        ->setCellValue('A1', $row_titles['TITLE01'])
        ->setCellValue('B1', $row_titles['TITLE02'])
        ->setCellValue('C1', $row_titles['TITLE03'])
        ->setCellValue('D1', $row_titles['TITLE04'])
        ->setCellValue('E1', $row_titles['TITLE05'])
        ->setCellValue('F1', $row_titles['TITLE06'])
        ->setCellValue('G1', $row_titles['TITLE07'])
        ->setCellValue('H1', $row_titles['TITLE08'])
        ->setCellValue('I1', $row_titles['TITLE09'])
        ->setCellValue('J1', $row_titles['TITLE10'])
        ->setCellValue('K1', $row_titles['TITLE11'])
        ->setCellValue('L1', $row_titles['TITLE12'])
        ->setCellValue('M1', $row_titles['TITLE13'])
        ->setCellValue('N1', $row_titles['TITLE14'])
        ->setCellValue('O1', $row_titles['TITLE15'])
        ->setCellValue('P1', $row_titles['TITLE16'])
        ->setCellValue('Q1', $row_titles['TITLE17'])
        ->setCellValue('R1', $row_titles['TITLE18'])
        ->setCellValue('S1', $row_titles['TITLE19'])
        ->setCellValue('T1', $row_titles['TITLE20'])
        ->setCellValue('U1', $row_titles['TEAM_TX'])
        ->setCellValue('V1', $row_titles['T_SHIRT_SIZE'])
        ->setCellValue('W1', $row_titles['INPUT1_TX'])
        ->setCellValue('X1', $row_titles['INPUT2_TX'])
        ->setCellValue('Y1', $row_titles['INPUT3_TX'])
        ->setCellValue('Z1', $row_titles['INPUT4_TX']);

        // Rename worksheet
        $objPHPExcel->getActiveSheet()->setTitle('Participants');

        // Set active sheet index to the first sheet, so Excel opens this as the first sheet
        $objPHPExcel->setActiveSheetIndex(0);

        // Save Excel5 file
        //echo date('H:i:s') , " Write to Excel5 format" , EOL;
        $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
        $objWriter->save(str_replace('.html', '.xls', __FILE__));

        // We'll be outputting an excel file
        header('Content-type: application/vnd.ms-excel');

        // It will be called file.xls
        header('Content-Disposition: attachment; filename="file.xls"');

        // Write file to the browser
        $objWriter->save('php://output');

我希望这段话能有所帮助,因为我对PHP也是新手。


0

我曾经遇到过同样的问题,响应中出现了乱码,而且无法打开 Excel 文件。 解决方法是不要使用表单提交或 AJAX 调用,只需使用 document.location 来转发 Excel 生成器的进程。 例如:

document.location="/php/Controller/YnrAPICall.php?is_string=1&params="+ JSON.stringify(params);

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接