5

我有一个用 PHPExcel 制作的 Excel 文件,它有一个带有左对齐徽标和右对齐日期和用户文本的标题。对于第一页,我想要一个类似的标题(相同的徽标和相同的日期和用户文本),但添加了一些信息(文件的标题和参数在几行之后居中)。

到目前为止,这就是我正在做的事情:

<?php

    $sheet = $this->_spreadsheet->getActiveSheet(); //_spreadsheet is an instance of PHPExcel

    $logo = new PHPExcel_Worksheet_HeaderFooterDrawing();
    $logo->setName('Logo');
    $logo->setPath(DOCUMENT_ROOT . '/public/logo.jpg'); //Path is OK & tested under PHP
    $logo->setHeight(38); //If image is larger/smaller than that, image will be proportionally resized
    $sheet->getHeaderFooter()->addImage($logo, PHPExcel_Worksheet_HeaderFooter::IMAGE_HEADER_LEFT);

    $sheet->getHeaderFooter()->setOddHeader('&L&G&RExport date: ' . date('Y-m-d H:i:s') . "\n" . 'User: ' . $user->name);

    if ($grid->getTitle() != '') {
        $sheet->getHeaderFooter()->setDifferentFirst(true);

        $sheet->getHeaderFooter()->addImage($logo, PHPExcel_Worksheet_HeaderFooter::IMAGE_HEADER_LEFT);
        $sheet->getHeaderFooter()->setFirstHeader('&L&G&C&"-,Bold"' . "\n\n\n" . $grid->getTitle() . "\n" . $grid->getParameters() . '&RExport date: ' . date('Y-m-d H:i:s') . "\n" . 'User: ' . $user->name);
    }

?>

对于“常规”标题,徽标和文本都在那里,所以一切正常。对于第一页标题,我有两个问题:

  1. 徽标未显示在第一页标题上(但文本正常)。
  2. 由于居中的标题后面会跟着一些文本(使用getParameters动态加载),我希望第一页标题能够拉伸以适应它的内容。

我怎样才能用 PHPExcel 做到这一点?

4

1 回答 1

2

对于为什么徽标没有显示在首页标题上,我没有答案,但要拉伸高度以适应您需要手动更改页边距的内容。

我不确定最好的方法,无论是计算换行符还是什么。但是一旦你知道你有多少行,你可以这样做:

$headerHeight = ( $imageHeight / 72 ) + ( $headerLineCount * $lineHeight );
$objPHPExcel->getActiveSheet()->getPageMargins()->setHeader( $margin );
$objPHPExcel->getActiveSheet()->getPageMargins()->setTop( $margin + $headerHeight );

** "$imageHeight / 72" 子句只是猜测如何将图像的屏幕高度转换为英寸。

于 2012-02-14T18:07:08.290 回答