拒绝?我相信我不是第一个遇到这个问题的人。
我正在尝试使用 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
是最后一行数据。