Apache POI 4 - создание диаграммы LINE с несколькими пустыми ячейками - PullRequest
0 голосов
/ 06 ноября 2019

Мне нравится создавать базу линейных диаграмм на моем источнике данных, но, к сожалению, когда линейная диаграмма y-ряда по нескольким ячейкам во время чата сюжета наталкивается на NullPointException.

Я обнаружил, что ошибка произошла, покастолбец был пустым и принудительно устанавливал «0», чтобы он работал.

В любом случае, я мог бы построить график на пустых ячейках без жестко закодированного «0»?

Ниже описан способ, какя жестко запрограммировал значение по умолчанию,

for (int i = 0; headers.size() > i; i++) {
    row.createCell(i, CellType.NUMERIC);
}

Ниже приведен код LineChart:

int rows = numberOfRows - 1;
int cols = headers.size();

XSSFDrawing drawing = sheet.createDrawingPatriarch();
XSSFClientAnchor anchor = drawing.createAnchor(0, 0, 0, 0, 0, 5, 10, 15);
XSSFChart chart = drawing.createChart(anchor);
chart.displayBlanksAs(DisplayBlanks.GAP);

XDDFChartLegend legend = chart.getOrAddLegend();
legend.setPosition(LegendPosition.TOP_RIGHT);

// Use a category axis for the bottom axis.
XDDFCategoryAxis bottomAxis = chart.createCategoryAxis(AxisPosition.BOTTOM);
bottomAxis.setOrientation(AxisOrientation.MAX_MIN);
bottomAxis.setTitle("Date");

XDDFValueAxis rightAxis = chart.createValueAxis(AxisPosition.RIGHT);
rightAxis.setTitle("Rates");
rightAxis.setCrosses(AxisCrosses.AUTO_ZERO);

XDDFChartLegend chartLegend = chart.getOrAddLegend();
chartLegend.setPosition(LegendPosition.TOP_RIGHT);
chartLegend.setOverlay(false);

XDDFLineChartData lineChartData = (XDDFLineChartData) chart.createData(ChartTypes.LINE, bottomAxis, rightAxis);
lineChartData.setVaryColors(false);

XDDFDataSource<String> xs = XDDFDataSourcesFactory.fromStringCellRange(sheet, new CellRangeAddress(1, rows, 1, 1));

for (int col = 2; cols > col; col++) {
    XDDFNumericalDataSource<Double> ys = XDDFDataSourcesFactory.fromNumericCellRange(sheet, new CellRangeAddress(1, rows, col, col));
    XDDFLineChartData.Series series = (XDDFLineChartData.Series) lineChartData.addSeries(xs, ys);
    series.setTitle(headers.get(col), null);
    series.setSmooth(false);
    series.setMarkerStyle(MarkerStyle.NONE);
}

chart.plot(lineChartData);
...