jk2*_*674 7 java charts export-to-excel apache-poi
我从头开始创建一个Excel工作簿.其中一个工作表包含图表,我想设置图表标题.
Apache POI在HSSFChart上有一个setChartTitle方法,但XSSFChart和格式不可知的Chart都没有设置图表标题的方法.由于我需要创建.xlsx文件,这对我来说是一个问题.
在对POI代码和OOXML规范进行了大量探讨之后,我设法提出了这个代码,用于在新创建的图表上设置标题:
if (chart instanceof XSSFChart) {
XSSFChart xchart = (XSSFChart) chart;
CTChart ctChart = xchart.getCTChart();
CTTitle title = ctChart.addNewTitle();
CTTx tx = title.addNewTx();
CTTextBody rich = tx.addNewRich();
rich.addNewBodyPr(); // body properties must exist, but can be empty
CTTextParagraph para = rich.addNewP();
CTRegularTextRun r = para.addNewR();
r.setT("My chart title");
}
Run Code Online (Sandbox Code Playgroud)
这似乎工作 - 我可以在Excel 2013中加载生成的文件,图表是正确的标题.
有更简单的方法吗?在Excel中创建的工作簿中更改图表标题时,我需要注意哪些问题?
这个问题六年来一直没有答案,答案如下:
您可以使用XSSFChart.setTitleText(String title)方法。
例子:
import java.io.FileOutputStream;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xddf.usermodel.chart.ChartTypes;
import org.apache.poi.xddf.usermodel.chart.XDDFChartData;
import org.apache.poi.xddf.usermodel.chart.XDDFDataSource;
import org.apache.poi.xddf.usermodel.chart.XDDFDataSourcesFactory;
import org.apache.poi.xddf.usermodel.chart.XDDFNumericalDataSource;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.apache.poi.xssf.usermodel.XSSFChart;
import org.apache.poi.xssf.usermodel.XSSFDrawing;
public class Chart {
public static void main(String[] args) throws Exception {
try (Workbook wb = new XSSFWorkbook(); FileOutputStream fileOut = new FileOutputStream("chart.xlsx");) {
Sheet sheet = wb.createSheet("Sheet1");
XSSFDrawing drawing = (XSSFDrawing)sheet.createDrawingPatriarch();
XSSFChart chart = drawing.createChart(drawing.createAnchor(0, 0, 0, 0, 0, 0, 12, 12));
// ---------------------> Here we set the title
chart.setTitleText("My chart title");
// <---------------------
XDDFDataSource<String> cat = XDDFDataSourcesFactory.fromArray(new String[]{"A","B","C","D"});
XDDFNumericalDataSource<Double> val = XDDFDataSourcesFactory.fromArray(new Double[]{1d, 2d, 3d, 4d});
XDDFChartData data = chart.createData(ChartTypes.PIE, null, null);
data.setVaryColors(true);
XDDFChartData.Series series = data.addSeries(cat, val);
series.setTitle("Series", null);
chart.plot(data);
wb.write(fileOut);
} catch (Exception e) {
e.printStackTrace();
}
}
}
Run Code Online (Sandbox Code Playgroud)
据我所知XSSFChart.setTitleText("My chart title"),当提出这个问题时,这是不可用的。
| 归档时间: |
|
| 查看次数: |
2625 次 |
| 最近记录: |