1

拒绝?我相信我不是第一个遇到这个问题的人。

我正在尝试使用 PHPExcel 和 Excel5 库创建图表以生成 '95 格式的 .xls 文件。

除了图表本身的创建/保存外,一切顺利。该文件被保存/下载/打开,没有任何错误警告,PHPExcel 在创建/保存期间或 Excel 在打开文件期间警告。

唯一真正的问题是,在创建的 Excel '95 .xls 文件中看不到图表。

我已检查以确保将 MIME 类型设置为 '95 .xls 格式application/vnd.ms-excel。这是。

这是与图表创建相关的代码,目前它有点乱,但就像我说的,它就像 2007 版本的魅力:

//ADD THE REPORT SUMMARY CHART
$labels = array(
    new PHPExcel_Chart_DataSeriesValues('String', "'Report Summary'!C1", null, 1),
    new PHPExcel_Chart_DataSeriesValues('String', "'Report Summary'!D1", null, 1)
);
$chrtCols = "'Report Summary'!B2:B$rowNum";
$chrtVals = "'Report Summary'!C2:C$rowNum";
$chrtVals2 = "'Report Summary'!D2:D$rowNum";
$periods = new PHPExcel_Chart_DataSeriesValues('String', $chrtCols, null, $rowNum-1);
$values = new PHPExcel_Chart_DataSeriesValues('Number', $chrtVals, null, $rowNum-1);
$values2 = new PHPExcel_Chart_DataSeriesValues('Number', $chrtVals2, null, $rowNum-1);
$series = new PHPExcel_Chart_DataSeries(
    PHPExcel_Chart_DataSeries::TYPE_LINECHART,       
    PHPExcel_Chart_DataSeries::GROUPING_STANDARD,  
    array(0,1),                                       
    $labels,                                       
    array($periods,$periods),                               
    array($values,$values2)                                  
);
$series->setPlotDirection(PHPExcel_Chart_DataSeries::DIRECTION_COL);
$layout = new PHPExcel_Chart_Layout();

$plotarea = new PHPExcel_Chart_PlotArea($layout, array($series));
$chart = new PHPExcel_Chart('sample', null, null, $plotarea);
$chart->setTopLeftPosition('A1', 24, 24);
$chart->setBottomRightPosition('B18', -24);
$actSheet->addChart($chart);

问题似乎与 '95 版本有关,因为完全相同的代码可用于创建文件的有效 2007 版本(使用 Excel_2007 类而不是 Excel5)。

有什么想法吗?与 Excel_95 相比,Excel_07 中的折线图构造是否不同(或标签定义不同)?我应该添加/修改/删除 $series 数组中的任何其他声明以使图表显示 Excel_95?

是的,我包括$objWriter->setIncludeCharts(TRUE);在编写文件之前。

$rowNum是最后一行数据。

4

1 回答 1

2

PHPExcel 只支持 Excel2007 读写器的图表;该功能尚未为 Excel5 读/写器编写

于 2013-10-14T21:52:20.620 回答