Java使用poi和jfreechart生成excel图表图片

2024-09-02 13:38

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

      最近项目在频繁的操作excel,里边涉及到很多和图表有关的东西。有时候需要使用java操作excel自带的图标,比较复杂的我们都是使用excel模板的形式实现。 
除此之外,也有一些功能只需要生成对应的图标样式的图片就好,我们实现的时候主要用了两种方式,一种就是由前台生成图片base64码,然后后台解码生成图片插入到excel,但是这种方式有 一定的局限性,也就是当某些功能需要后台定时生成excel的时候,就无法获取这个图片。 
     于是我采用了另一种方法,也就是是用jfreechart生成对应的图片,然后结合poi插入到excel对应的位置,下图是项目中使用后的真实效果: 
图1是前端base64码生成的: 

图2是后台jfreechart生成的: 

以下是抽空做的一个简单的整理: 
1、maven导包:

<dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml</artifactId><version>3.8</version>
</dependency>
<dependency><groupId>org.apache.poi</groupId><artifactId>poi-scratchpad</artifactId><version>3.8</version>
</dependency>
<dependency><groupId>jfree</groupId><artifactId>jfreechart</artifactId><version>1.0.13</version>
</dependency>

2、java测试main方法代码:

package com.wangruTest;import java.awt.BasicStroke;
import java.awt.Color;
import java.awt.Font;
import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import javax.imageio.ImageIO;
import org.apache.poi.hssf.usermodel.HSSFClientAnchor;
import org.apache.poi.hssf.usermodel.HSSFPatriarch;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.jfree.chart.ChartColor;
import org.jfree.chart.ChartFactory;
import org.jfree.chart.ChartUtilities;
import org.jfree.chart.JFreeChart;
import org.jfree.chart.axis.CategoryAxis;
import org.jfree.chart.axis.CategoryLabelPositions;
import org.jfree.chart.axis.NumberAxis;
import org.jfree.chart.axis.NumberTickUnit;
import org.jfree.chart.axis.ValueAxis;
import org.jfree.chart.plot.CategoryPlot;
import org.jfree.chart.plot.PlotOrientation;
import org.jfree.chart.renderer.category.LineAndShapeRenderer;
import org.jfree.chart.title.LegendTitle;
import org.jfree.chart.title.TextTitle;
import org.jfree.data.category.DefaultCategoryDataset;
import org.jfree.ui.RectangleEdge;public class TestPoiAndJfreeChart {public static void main(String[] args) throws Exception {// excel2003工作表HSSFWorkbook wb = new HSSFWorkbook();HSSFSheet sheet = wb.createSheet("Sheet 1");ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream();;// 设置具体数据List<String> timeList = new ArrayList<String>();timeList.add("10:00");timeList.add("11:00");timeList.add("12:00");List<Integer> appList = new ArrayList<Integer>();appList.add(120);appList.add(200);appList.add(150);List<Integer> oraList = new ArrayList<Integer>();oraList.add(230);oraList.add(200);oraList.add(235);// 设置图片中的字体和颜色以及字号Font titleFont = new Font("黑体", Font.BOLD, 12);Font xfont = new Font("黑体", Font.BOLD, 10);Font labelFont = new Font("黑体", Font.BOLD, 10);// 设置数据区域DefaultCategoryDataset dataset = new DefaultCategoryDataset();for (int i = 0; i < timeList.size(); i++) {String time = timeList.get(i);dataset.addValue(appList.get(i), "苹果", time);dataset.addValue(oraList.get(i), "橘子", time);}JFreeChart chart = ChartFactory.createLineChart("水果时间段销量", "时间", "销量", dataset, PlotOrientation.VERTICAL, true,true, true);// 设置图例字体chart.getLegend().setItemFont(new Font("黑体", Font.BOLD, 10));// 设置标题字体chart.setTitle(new TextTitle(chart.getTitle().getText(), titleFont));// 图形的绘制结构对象CategoryPlot plot = chart.getCategoryPlot();// 获取显示线条的对象LineAndShapeRenderer lasp = (LineAndShapeRenderer) plot.getRenderer();// 设置拐点是否可见/是否显示拐点lasp.setBaseShapesVisible(true);// 设置拐点不同用不同的形状lasp.setDrawOutlines(true);// 设置线条是否被显示填充颜色lasp.setUseFillPaint(false);LineAndShapeRenderer renderer = (LineAndShapeRenderer) plot.getRenderer();// 设置折线大小以及折线的颜色renderer.setSeriesStroke(0, new BasicStroke(1.0F));renderer.setSeriesPaint(0, new Color(210, 105, 30));renderer.setSeriesStroke(1, new BasicStroke(1.0F));renderer.setSeriesPaint(1, new Color(0, 191, 255));// 设置折点的大小lasp.setSeriesOutlineStroke(0, new BasicStroke(0.025F));lasp.setSeriesOutlineStroke(1, new BasicStroke(0.05F));// 设置网格线plot.setDomainGridlinePaint(Color.gray);plot.setDomainGridlinesVisible(true);plot.setRangeGridlinePaint(Color.gray);plot.setRangeGridlinesVisible(true);// x轴CategoryAxis domainAxis = plot.getDomainAxis();// 设置x轴不显示,即让x轴和数据区重合domainAxis.setAxisLineVisible(false);// x轴标题domainAxis.setLabelFont(xfont);// x轴数据倾斜domainAxis.setCategoryLabelPositions(CategoryLabelPositions.createUpRotationLabelPositions(0.95D));// X轴坐标上数值字体domainAxis.setTickLabelFont(labelFont);// 设置Y轴间隔NumberAxis numAxis = (NumberAxis) plot.getRangeAxis();numAxis.setTickUnit(new NumberTickUnit(50));// y轴ValueAxis rangeAxis = plot.getRangeAxis();rangeAxis.setLabelFont(xfont);// 设置y轴不显示,即和数据区重合rangeAxis.setAxisLineVisible(false);// y轴坐标上数值字体rangeAxis.setTickLabelFont(labelFont);rangeAxis.setFixedDimension(0);CategoryPlot cp = chart.getCategoryPlot();// 背景色设置cp.setBackgroundPaint(ChartColor.WHITE);cp.setRangeGridlinePaint(ChartColor.GRAY);// 创建图例,设置图例的位置,这里的设置实际不起作用,怎么设都在下边LegendTitle legendTitle = new LegendTitle(chart.getPlot());legendTitle.setPosition(RectangleEdge.BOTTOM);try {ChartUtilities.writeChartAsPNG(byteArrayOut, chart, 400, 200);String fileSavePath = "exTest.png";BufferedImage bufferImg = ImageIO.read(new File(fileSavePath));ImageIO.write(bufferImg, "png", byteArrayOut);} catch (IOException e) {}// 画图的顶级管理器,一个sheet只能获取一个(一定要注意这点)HSSFPatriarch patriarch = sheet.createDrawingPatriarch();// 八个参数,前四个表示图片离起始单元格和结束单元格边缘的位置,// 后四个表示起始和结束单元格的位置,如下表示从第2列到第12列,从第1行到第15行,需要注意excel起始位置是0HSSFClientAnchor anchor = new HSSFClientAnchor(0, 0, 0, 0, (short) 2, (short) 1, (short) 12, (short) 15);anchor.setAnchorType(3);// 插入图片patriarch.createPicture(anchor, wb.addPicture(byteArrayOut.toByteArray(), HSSFWorkbook.PICTURE_TYPE_PNG));// excel2003后缀FileOutputStream fileOut = new FileOutputStream("D://myExcel.xls");wb.write(fileOut);fileOut.close();}
}

从D盘中找到myExcel.xls,用office打开,结果如图: 

这篇关于Java使用poi和jfreechart生成excel图表图片的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

redis中使用lua脚本的原理与基本使用详解

《redis中使用lua脚本的原理与基本使用详解》在Redis中使用Lua脚本可以实现原子性操作、减少网络开销以及提高执行效率,下面小编就来和大家详细介绍一下在redis中使用lua脚本的原理... 目录Redis 执行 Lua 脚本的原理基本使用方法使用EVAL命令执行 Lua 脚本使用EVALSHA命令

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

利用Python打造一个Excel记账模板

《利用Python打造一个Excel记账模板》这篇文章主要为大家详细介绍了如何使用Python打造一个超实用的Excel记账模板,可以帮助大家高效管理财务,迈向财富自由之路,感兴趣的小伙伴快跟随小编一... 目录设置预算百分比超支标红预警记账模板功能介绍基础记账预算管理可视化分析摸鱼时间理财法碎片时间利用财

Maven中引入 springboot 相关依赖的方式(最新推荐)

《Maven中引入springboot相关依赖的方式(最新推荐)》:本文主要介绍Maven中引入springboot相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有... 目录Maven中引入 springboot 相关依赖的方式1. 不使用版本管理(不推荐)2、使用版本管理(推

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B

如何在 Spring Boot 中实现 FreeMarker 模板

《如何在SpringBoot中实现FreeMarker模板》FreeMarker是一种功能强大、轻量级的模板引擎,用于在Java应用中生成动态文本输出(如HTML、XML、邮件内容等),本文... 目录什么是 FreeMarker 模板?在 Spring Boot 中实现 FreeMarker 模板1. 环

使用Python和Pyecharts创建交互式地图

《使用Python和Pyecharts创建交互式地图》在数据可视化领域,创建交互式地图是一种强大的方式,可以使受众能够以引人入胜且信息丰富的方式探索地理数据,下面我们看看如何使用Python和Pyec... 目录简介Pyecharts 简介创建上海地图代码说明运行结果总结简介在数据可视化领域,创建交互式地

SpringMVC 通过ajax 前后端数据交互的实现方法

《SpringMVC通过ajax前后端数据交互的实现方法》:本文主要介绍SpringMVC通过ajax前后端数据交互的实现方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价... 在前端的开发过程中,经常在html页面通过AJAX进行前后端数据的交互,SpringMVC的controll