使用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 test;
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;
/**
* 结合poi和jfreechart创建图表图片
*
* @author tuzongxun
* @date 2016年9月19日 上午10:55:09
*/
public class ExcelDemo2 {
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起始位置是0
HSSFClientAnchor 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("exTest.xls");
wb.write(fileOut);
fileOut.close();
}
}
结果如图:
使用poi和jfreechart生成excel图表图片的更多相关文章
- 利用JFreeChart生成组合图表 (8) (转自 JSP开发技术大全)
利用JFreeChart生成组合图表 (8) (转自 JSP开发技术大全) 14.8 利用JFreeChart生成组合图表 实例位置:光盘\mingrisoft\14\dxyy\02 通过JFree ...
- JAVA生成EXCEL图表
跟据客户的要求,需要开发一套包括图形的报表,还需要导出WORD 图表需要这样: 这样: 这样: 还有这样: 接下来是实现思路: 以往用的最多的就是JFreechart,手上也有实现各种图形的资源,但是 ...
- phantomjs server + highchart 在服务器端生成highchart图表图片
前言 当项目需要将一个highchart图表以邮件发送的时候,js+css形式的highcharts 图表肯定是不好做的,有查可以借助flash去执行js,但很麻烦,所以折中将highchart图表转 ...
- python生成Excel图表(通过xlsxwriter)
前面介绍了pandas的简单用法,pandas的数据可以通过matlab第三方包将数据生成报表,但是我想将报表生成在Excel中,这时候就可以借助xlsxwriter第三方包来生成图标 缺点:xl ...
- 【JAVA】POI生成EXCEL图表(柱状图、折线等)
1.使用excel工具自带的图形工具创建一个图: 2.绑定数据区域: 3.数据区域绑定完成,我们要做的就是将数据写入到数据区域中: 4.标记 5.POI 引入包 <!-- https://mvn ...
- springboot2.1.8使用poi导出数据生成excel(.xlsx)文件
前言:在实际开发中经常需要将数据库的数据导出成excel文件,poi方式则是其中一种较为常用的导出框架.简单读取excel文件在之前的一篇有说明 本项目实现需求:user发出一个导出student信息 ...
- 是用Epplus生成Excel 图表
1. 前言 这是我最近项目刚要的需求,然后在网上找了半天的教材 但是很不幸,有关于Epplus的介绍真的太少了,然后经过了我的不断研究然后不断的采坑,知道现在看到Excel都想吐的时候,终于成功的 ...
- POI tools 参数化生成excel表格
package com.eccom.neteagle.server.confsave.service.impl; import java.io.File; import java.io.FileNot ...
- 使用Epplus生成Excel 图表
1. 前言 这是我最近项目刚要的需求,然后在网上找了半天的教材 但是很不幸,有关于Epplus的介绍真的太少了,然后经过了我的不断研究然后不断的采坑,知道现在看到Excel都想吐的时候,终于成功的 ...
随机推荐
- Jmeter_24个常用函数(分享帖)
JMeter提供了很多函数,如果能够熟练使用,可以为脚本带来很多方便. JMeter函数是一种特殊值,可用于除测试计划外的任何组件. 函数调用的格式如下所示:${__functionName(var1 ...
- remap.config文件配置模板
# # URL Remapping Config File # # Using remap.config allows you to accomplish two things: # # 1) Rew ...
- 编译和解释性语言和python运行方式
1.编译型语言和解释性语言 编译型语言:在执行之前需要一个专门的编译过程,把程序编译成为机器语言的文件,运行时不需要重新翻译,直接使用编译的结果就行了.程序执行效率高,依赖编译器,跨平台性差些.如C. ...
- WPF中,多key值绑定问题,一个key绑定一个界面上的对象
问题说明: 当用到dictionary<key,value>来储存数据的时候,有时候需要在界面上绑定一个key来显示value,这时候有两种思路: 一种是写一个自定义的扩展类,类似Bind ...
- c# 实现mysql事务
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- 使用py2exe发布windows平台Python
一.简介 py2exe是一个将python脚本转换成windows上的可独立执行的可执行程序(*.exe)的工具,这样,你就可以不用装python而在windows系统上运行这个可执行程序.py2ex ...
- NIO基础篇(三)
NIO里对性能提升最显著的是内存映射(memory mapping),内存访问的速度往往比文件访问的速度快几个数量级. 在内存映射之前,还需要看NIO的一些其他的特性. 缓冲区分片 slice()方法 ...
- BZOJ 1299: [LLH邀请赛]巧克力棒 [组合游戏]
每次一人可以从盒子里取出若干条巧克力棒,或是将一根取出的巧克力棒吃掉正整数长度. Nim游戏多了一个决策:拿出一些石堆 显然只要给对方构造异或和为0的子集就行了 暴枚子集... #include &l ...
- BZOJ 1040: [ZJOI2008]骑士 [DP 环套树]
传送门 题意:环套树的最大权独立集 一开始想处理出外向树树形$DP$然后找到环再做个环形$DP$ 然后看了看别人的题解其实只要断开环做两遍树形$DP$就行了...有道理! 注意不连通 然后洛谷时限再次 ...
- CentOS上安装GitBlit服务
简单介绍 在上一篇文章中,已经简单的介绍了如何在CentOS的服务器上搭建git服务器.但是这种方式实现的服务器功能比较弱,操作起来也比较繁琐.在网上搜索了一圈,感觉Gitblit比较符合我的需求.接 ...