PHPExcel - Excel5 - 创建折线图 - 图表缺失

Posted

技术标签:

【中文标题】PHPExcel - Excel5 - 创建折线图 - 图表缺失【英文标题】:PHPExcel - Excel5 - Create Line Chart - Chart Missing 【发布时间】:2013-10-22 13:56:44 【问题描述】:

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

我正在尝试使用 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 是最后一行数据。

【问题讨论】:

【参考方案1】:

PHPExcel 只支持 Excel2007 读写器的图表;该功能还没有为 Excel5 读写器编写

【讨论】:

嗯,这肯定可以解释为什么它不起作用。哈哈。好东西我在花了几个小时试图自己解决之前在这里发布。再次感谢!附言是否正在为 PHPExcel_5 类开发对 '95 图表的支持,或者 '95 格式是否被认为已过时并且在这一点上浪费代码? 它会及时出现,但目前我仍在完善 PHPExcel 核心中图表结构的细节 是的。当然需要时间。很难想象你有时间通过​​你所做的所有问答来发展。不过对我这样的人来说还是不错的。无论如何,继续做好工作。哦,一个(希望是最终的)后续问题,是否有文档中某处包含的类/函数的参考列表,所以我可以确定我在使用类/函数时添加了正确的变量、空值等或我只需要挖吗? Docs 发行版包括由 phpdocumentor 生成的 /Documents/API 列出类/方法/参数/等 啊哈!甜的。再次感谢。

以上是关于PHPExcel - Excel5 - 创建折线图 - 图表缺失的主要内容,如果未能解决你的问题,请参考以下文章

phpexcel

PHPExcel导出xls

PHPExcel帮助手册

PhpExcel使用方法

PhpExcel笔记,phpExcel中文帮助手册

PHPExcel类的使用讲解