Java POI生成Excel图表实战指南

Apache POI是Java生态中处理Office文档的核心工具,支持Excel图表的动态生成与数据绑定。本文以POI 5.x版本为例,详解如何在Excel中创建折线图、柱状图、饼图等常见图表,并提供代码示例与最佳实践。


一、环境配置与依赖管理

使用POI生成图表需引入以下核心依赖(以Maven为例):

xml 复制代码
XML
<dependency>  
    <groupId>org.apache.poi</groupId>  
    <artifactId>poi-ooxml</artifactId>  
    <version>5.2.3</version>  
</dependency>  

注意:POI 5.x版本与旧版本(如3.x)API差异较大,需避免依赖冲突


二、数据源准备与工作表构建

  1. 创建工作簿与工作表
ini 复制代码
Java
XSSFWorkbook workbook = new XSSFWorkbook();  
XSSFSheet sheet = workbook.createSheet("数据表");  
  1. 填充数据
    以国家GDP数据为例,首行写入国家名称,后续行填充数值:
scss 复制代码
Java
// 创建标题行  
Row headerRow = sheet.createRow(0);  
headerRow.createCell(0).setCellValue("国家");  
headerRow.createCell(1).setCellValue("俄罗斯");  
headerRow.createCell(2).setCellValue("中国");  
// 填充数据行  
Row dataRow = sheet.createRow(1);  
dataRow.createCell(0).setCellValue("GDP(万亿美元)");  
dataRow.createCell(1).setCellValue(1.78);  
dataRow.createCell(2).setCellValue(17.96);  

三、图表生成核心步骤

1. 折线图(Line Chart)
ini 复制代码
Java
// 定义图表位置与尺寸  
XSSFDrawing drawing = sheet.createDrawingPatriarch();  
XSSFClientAnchor anchor = drawing.createAnchor(0, 0, 0, 0, 0, 5, 10, 20);  

// 创建图表对象  
XSSFChart chart = drawing.createChart(anchor);  
chart.setTitleText("国家GDP趋势分析");  

// 绑定数据源  
XDDFDataSource<String> countries = XDDFDataSourcesFactory.fromStringCellRange(sheet, new CellRangeAddress(0, 0, 1, 2));  
XDDFNumericalDataSource<Double> values = XDDFDataSourcesFactory.fromNumericCellRange(sheet, new CellRangeAddress(1, 1, 1, 2));  

// 配置坐标轴与样式  
XDDFCategoryAxis xAxis = chart.createCategoryAxis(AxisPosition.BOTTOM);  
XDDFValueAxis yAxis = chart.createValueAxis(AxisPosition.LEFT);  
XDDFLineChartData data = (XDDFLineChartData) chart.createData(ChartTypes.LINE, xAxis, yAxis);  

// 添加数据系列并渲染  
XDDFLineChartData.Series series = data.addSeries(countries, values);  
series.setTitle("GDP", null);  
chart.plot(data);  

关键点 :通过CellRangeAddress绑定数据区域,支持动态扩展

2. 柱状图(Bar Chart)

柱状图与折线图代码结构类似,仅需修改图表类型与样式:

ini 复制代码
Java
XDDFBarChartData data = (XDDFBarChartData) chart.createData(ChartTypes.BAR, xAxis, yAxis);  

可通过XDDFShapeProperties自定义柱体颜色与间距

3. 饼图(Pie Chart)

饼图需单独设置数据标签与百分比显示:

scss 复制代码
Java
XDDFPieChartData data = (XDDFPieChartData) chart.createData(ChartTypes.PIE, null, null);  
XDDFPieChartData.Series series = data.addSeries(countries, values);  
chart.plot(data);  
// 启用百分比标签  
chart.getCTChart().getPlotArea().getPieChartArray(0).addNewDLbls().addNewShowPercent().setVal(true);  

四、常见问题与优化

  1. 图表位置偏移

    通过XSSFClientAnchor参数调整坐标(如col1, row1, col2, row2)控制图表位置

  2. 数据动态更新

    使用CellRangeAddress动态扩展数据范围,避免硬编码。例如:

ini 复制代码
Java
CellRangeAddress valuesRange = new CellRangeAddress(1, 1, 1, sheet.getRow(1).getLastCellNum());  
  1. 样式自定义
  • 坐标轴标题xAxis.setTitle("国家")

  • 图例位置chart.getOrAddLegend().setPosition(LegendPosition.TOP_RIGHT)

  • 颜色设置 :通过XDDFSolidFillProperties指定RGB值


五、总结

通过POI生成Excel图表的核心在于数据绑定API灵活调用。开发者需注意:

  1. 数据区域需与图表类型匹配(如分类轴与数值轴);
  2. 高版本POI(≥5.0)推荐使用XDDF系列API,兼容性更强;
  3. 复杂图表建议封装工具类(如ChartUtils)提升代码复用性
相关推荐
程序员岳焱4 小时前
Java 与 MySQL 性能优化:Java 实现百万数据分批次插入的最佳实践
后端·mysql·性能优化
麦兜*5 小时前
Spring Boot启动优化7板斧(延迟初始化、组件扫描精准打击、JVM参数调优):砍掉70%启动时间的魔鬼实践
java·jvm·spring boot·后端·spring·spring cloud·系统架构
大只鹅5 小时前
解决 Spring Boot 对 Elasticsearch 字段没有小驼峰映射的问题
spring boot·后端·elasticsearch
ai小鬼头5 小时前
AIStarter如何快速部署Stable Diffusion?**新手也能轻松上手的AI绘图
前端·后端·github
IT_10246 小时前
Spring Boot项目开发实战销售管理系统——数据库设计!
java·开发语言·数据库·spring boot·后端·oracle
bobz9656 小时前
动态规划
后端
stark张宇6 小时前
VMware 虚拟机装 Linux Centos 7.9 保姆级教程(附资源包)
linux·后端
亚力山大抵7 小时前
实验六-使用PyMySQL数据存储的Flask登录系统-实验七-集成Flask-SocketIO的实时通信系统
后端·python·flask
超级小忍7 小时前
Spring Boot 中常用的工具类库及其使用示例(完整版)
spring boot·后端
CHENWENFEIc8 小时前
SpringBoot论坛系统安全测试实战报告
spring boot·后端·程序人生·spring·系统安全·安全测试