PHPExcel创建一个新文件

时间:2015-04-16 15:41:46

标签: php ajax phpexcel

我正在尝试使用带有以下代码的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来进行这种操作。这可能是导致此错误的原因吗?

2 个答案:

答案 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);