PhpExcel创建多个工作表

时间:2013-10-06 20:32:56

标签: php phpexcel

你好我试图用phpexcel

创建一个excel模板

由于某种原因,图像会创建新工作表,而不是使用当前工作表。 因此,当我打开excel文件时,我已经创建了工作表工作表1 而不是单个文件。

   
    objPHPExcel = new PHPExcel();
            $objWorkSheet = $objPHPExcel->createSheet();            

             // Set the active Excel worksheet to sheet 0 
            $objPHPExcel->setActiveSheetIndex(0);  

            //Taslak Verileri
            $objPHPExcel->getActiveSheet()->SetCellValue('D'.'1', 'Firm'); 
            $objPHPExcel->getActiveSheet()->SetCellValue('J'.'1', 'SFUFORMU - FR.PS.21'); 
            $objPHPExcel->getActiveSheet()->SetCellValue('J'.'3', 'NO:'); 
            $objPHPExcel->getActiveSheet()->SetCellValue('D'.'2', 'Name Surname Signature'); 
            $objPHPExcel->getActiveSheet()->SetCellValue('A'.'4', 'Date');
            $objPHPExcel->getActiveSheet()->SetCellValue('A'.'5', 'Stock No:'); 
            $objPHPExcel->getActiveSheet()->SetCellValue('C'.'5', 'Image'); 
            $objPHPExcel->getActiveSheet()->SetCellValue('E'.'5', 'Image'); 
            $objPHPExcel->getActiveSheet()->SetCellValue('G'.'5', 'Resim'); 
            $objPHPExcel->getActiveSheet()->SetCellValue('I'.'5', 'Image'); 
            $objPHPExcel->getActiveSheet()->SetCellValue('K'.'5', 'Quantity'); 
            $objPHPExcel->getActiveSheet()->SetCellValue('M'.'5', 'Price'); 



            $objDrawing = new PHPExcel_Worksheet_Drawing();
                  $objDrawing->setWorksheet($objWorkSheet);
                  $objDrawing->setName("name");
                  $objDrawing->setDescription("Description");
                  $objDrawing->setPath('temp/3.jpeg');
                  $objDrawing->setCoordinates('F9');
                  $objDrawing->setOffsetX(1);
                  $objDrawing->setOffsetY(5);
            $objWriter = new PHPExcel_Writer_Excel2007($objPHPExcel); 
            $objWriter->save('some_excel_file.xlsx'); 

enter image description here

enter image description here

3 个答案:

答案 0 :(得分:9)

您基本上创建了一个PHPExcel对象,该对象已经是索引为0的空工作表。

然后您创建一个索引为1的新工作表。

然后您将所有内容写入索引为0的工作表,并在第二张(新创建)上添加图片。

这可以解决您的问题:

$objPHPExcel->setActiveSheetIndex(1); 

请注意,您仍然可以创建新工作表,即使第一个已经存在。 如果要使用现有工作表,请执行以下操作:

卸下:

   $objWorkSheet = $objPHPExcel->createSheet();            
   $objPHPExcel->setActiveSheetIndex(0); 

并使用现有的工作表完成所有工作。

$sheet = $objPHPExcel->getSheet(0);
$sheet->setCellValue('D'.'1', 'Firm')//Etc all the stuff.

为图纸提供相同的图纸:

$objDrawing->setWorksheet($sheet);

答案 1 :(得分:0)

我不知道规则 phpexcel ,但在您的上下文中显示您正在使用此方法创建两个工作表,因为您正在调用两次...

$objWorkSheet = $objPHPExcel->createSheet();  

$objDrawing->setWorksheet($objWorkSheet);

答案 2 :(得分:0)

使用PHPEXCEL

编写2张单个Excel工作簿
for ($i=0; $i <2 ; $i++) { 
    $objPHPExcel->getActiveSheet()->setTitle('Worksheet'); //sheetname
    $newsheet = $objPHPExcel->createSheet(); //sheet create
}