Java实战之利用POI生成Excel图表

2025-02-27 17:50
文章标签 java poi excel 图表 实战 生成

本文主要是介绍Java实战之利用POI生成Excel图表,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《Java实战之利用POI生成Excel图表》ApachePOI是Java生态中处理Office文档的核心工具,这篇文章主要为大家详细介绍了如何在Excel中创建折线图,柱状图,饼图等常见图表,需要的...

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

一、环境配置与依赖管理

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

<dependency>  
    <groupId>org.apache.poi</groupId>  
    <artifactId>poi-ooXML</artifactId>  
    <version>5.2.3</version>  
</dependency>  

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

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

创建工作簿与工作表

XSSFWorkbook workbook = new XSSFWorkbook();  
XSSFSheet sheet = workbook.createSheet("数据表");  

填充数据

以国家GDP数据为例,首行写入国家名称,后续行填充数值:

// 创建标题行  
Row headerkOpgnepDRow = sheet.createRow(0);  
headerRow.createCell(0).setCellValue("国家");  
headerRow.createCell(1).pythonsetCellValue("俄罗斯");  
headerRow.createCell(2).setCellValue("中国");  
// 填充数据行  
Row dataRow =kOpgnepD sheet.createRow(1);  
dataRow.createCell(0).setCellValue("GDP(万亿美元)");  
dataRow.createCell(1).setCellValue(1.78);  
dataRow.createCell(2).setCellValue(17.96);  

三、图表生成核心步骤

1. 折线图(Line Chart)

// 定义图表位置与尺寸  
XSkOpgnepDSFDrawing 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)

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

XDDFBarChartData data = (XDDFBarChartData) chart.createData(ChartTypes.BAR, xAxis, yAxis);  

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

3. 饼图(Pie Chart)

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

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动态扩展数据范围,避免硬编码。例如:

CellRangeAddress valuesRange = new CellRangeAddress(1, 1, 1, sheet.getRow(1).getLastCellNum());  

3.样式自定义

  • 坐标轴标题xAxis.setTitle("国家")
  • 图例位置chart.getOrAddLegend().setPosition(LegenpythondPosition.TOP_RIGHT)
  • 颜色设置:通过XDDFSolidFillProperties指定RGB值 

五、总结

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

  • 数据区域需与图表类型匹配(如分类轴与数值轴);
  • 高版本POI(≥5.0)推荐使用XDDF系列API,兼容性更强;
  • 复杂图表建议封装工具类(如ChartUtils)提升代码复用性

到此这篇关于Java实战之利用POI生成Excel图表的文章就介绍到这了,更多相关Java POI生成Excel内容请搜索China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程China编程(www.chinasem.cn)!

这篇关于Java实战之利用POI生成Excel图表的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1153570

相关文章

SpringBoot启动报错的11个高频问题排查与解决终极指南

《SpringBoot启动报错的11个高频问题排查与解决终极指南》这篇文章主要为大家详细介绍了SpringBoot启动报错的11个高频问题的排查与解决,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一... 目录1. 依赖冲突:NoSuchMethodError 的终极解法2. Bean注入失败:No qu

Java异常架构Exception(异常)详解

《Java异常架构Exception(异常)详解》:本文主要介绍Java异常架构Exception(异常),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. Exception 类的概述Exception的分类2. 受检异常(Checked Exception)

使用Java实现通用树形结构构建工具类

《使用Java实现通用树形结构构建工具类》这篇文章主要为大家详细介绍了如何使用Java实现通用树形结构构建工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录完整代码一、设计思想与核心功能二、核心实现原理1. 数据结构准备阶段2. 循环依赖检测算法3. 树形结构构建4. 搜索子

Spring定时任务只执行一次的原因分析与解决方案

《Spring定时任务只执行一次的原因分析与解决方案》在使用Spring的@Scheduled定时任务时,你是否遇到过任务只执行一次,后续不再触发的情况?这种情况可能由多种原因导致,如未启用调度、线程... 目录1. 问题背景2. Spring定时任务的基本用法3. 为什么定时任务只执行一次?3.1 未启用

springboot报错Invalid bound statement (not found)的解决

《springboot报错Invalidboundstatement(notfound)的解决》本文主要介绍了springboot报错Invalidboundstatement(not... 目录一. 问题描述二.解决问题三. 添加配置项 四.其他的解决方案4.1 Mapper 接口与 XML 文件不匹配

MySQL新增字段后Java实体未更新的潜在问题与解决方案

《MySQL新增字段后Java实体未更新的潜在问题与解决方案》在Java+MySQL的开发中,我们通常使用ORM框架来映射数据库表与Java对象,但有时候,数据库表结构变更(如新增字段)后,开发人员可... 目录引言1. 问题背景:数据库与 Java 实体不同步1.1 常见场景1.2 示例代码2. 不同操作

SpringBoot使用OkHttp完成高效网络请求详解

《SpringBoot使用OkHttp完成高效网络请求详解》OkHttp是一个高效的HTTP客户端,支持同步和异步请求,且具备自动处理cookie、缓存和连接池等高级功能,下面我们来看看SpringB... 目录一、OkHttp 简介二、在 Spring Boot 中集成 OkHttp三、封装 OkHttp

JavaScript错误处理避坑指南

《JavaScript错误处理避坑指南》JavaScript错误处理是编程过程中不可避免的部分,它涉及到识别、捕获和响应代码运行时可能出现的问题,本文将详细给大家介绍一下JavaScript错误处理的... 目录一、错误类型:三大“杀手”与应对策略1. 语法错误(SyntaxError)2. 运行时错误(R

利用Python开发Markdown表格结构转换为Excel工具

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一... 目录1.完整代码2. 项目概述3. 代码解析3.1 依赖库3.2 GUI 设计3.3 解析 Mark

SpringBoot如何通过Map实现策略模式

《SpringBoot如何通过Map实现策略模式》策略模式是一种行为设计模式,它允许在运行时选择算法的行为,在Spring框架中,我们可以利用@Resource注解和Map集合来优雅地实现策略模式,这... 目录前言底层机制解析Spring的集合类型自动装配@Resource注解的行为实现原理使用直接使用M