我正在尝试使用带有以下代码的PHPExcel库创建一个新的Excel文件:
include ('/lib/PHPExcel/PHPExcel/IOFactory.php');
include ('/lib/PHPExcel/PHPExcel.php');
$objPHPExcel = new PHPExcel();
$objPHPExcel->getProperties()
->setCreator("admin")
->setLastModifiedBy("admin")
->setTitle("Test")
->setSubject("template file")
->setDescription("template file")
->setKeywords("Prout");
$objPHPExcel->setActiveSheetIndex(0);
$objPHPExcel->getActiveSheet()->SetCellValue('A1', 'Hello');
$objPHPExcel->getActiveSheet()->setTitle('Simple');
$objWriter = new PHPExcel_Writer_Excel2007($objPHPExcel);
$objWriter->save(dirname(__FILE__).'/file/test.xlsx');
该文件已创建,但当我尝试打开它时,我的excel 2010告诉我文件中有不可读的内容,我无法打开它。
我在不同的论坛上尝试了不同的方式,但我总是得到相同的结果。我通过使用Ajax和jquery来进行这种操作。这可能是导致此错误的原因吗?
答案 0 :(得分:3)
我找到了如何解决我的问题...但只有一半。因为它可以使用此代码:
$objPHPExcel = new PHPExcel();
$objPHPExcel->getProperties()
->setCreator("Temporaris")
->setLastModifiedBy("Temporaris")
->setTitle("Template Relevé des heures intérimaires")
->setSubject("Template excel")
->setDescription("Template excel permettant la création d'un ou plusieurs relevés d'heures")
->setKeywords("Template excel");
$objPHPExcel->setActiveSheetIndex(0);
$objPHPExcel->getActiveSheet()->SetCellValue('A1', "12");
$writer = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition: attachment;filename="excel.xls"');
header('Cache-Control: max-age=0');
$writer->save('php://output');
但它的Excel5不是Excel2007,当我用Excel2007重新设置Excel5时,我有相同的错误信息。
答案 1 :(得分:0)
你试过这个吗?
$objWriter = new PHPExcel_Writer_Excel2007($objPHPExcel);