Java 在Excel中添加分离型饼图、环形图
一、概述
Excel中可支持多种不同类型的图表,本文介绍如何绘制分离型饼图和环形图。其中,分离型饼图的绘制可分为整体分离型(即设置饼图分离程度)和局部分离(即设置点爆炸型值)两种情况。下面将以Java程序代码介绍如何在Excel中实现以上图形。
二、程序环境
- Spire.Xls.jar
- Jdk 1.8.0(版本>=1.6.0即可)
- IDEA
注:Jar使用的是Free Spire.XLS for Java(免费版)中的Spire.Xls.jar。编辑代码前,导入jar到Java程序,两种方法可导入(任选其一即可):
1. 下载jar包,解压导入lib文件夹下的jar到Java程序;
2. maven程序中配置pom.xml文件,指定spire的maven路径及依赖,参考如下:
- <repositories>
- <repository>
- <id>com.e-iceblue</id>
- <url>http://repo.e-iceblue.cn/repository/maven-public/</url>
- </repository>
- </repositories>
- <dependencies>
- <dependency>
- <groupId>e-iceblue</groupId>
- <artifactId>spire.xls.free</artifactId>
- <version>3.9.1</version>
- </dependency>
- </dependencies>
配置完成后,导入jar到程序。
三、Java代码
1. 分离型饼图
- import com.spire.xls.*;
- import com.spire.xls.charts.ChartSerie;
- import java.awt.*;
- public class ExplodedPieChart {
- public static void main(String[] args) {
- //创建Workbook对象
- Workbook workbook = new Workbook();
- //获取第一个工作表
- Worksheet sheet = workbook.getWorksheets().get(0);
- //将图表数据写入工作表
- sheet.getCellRange("A1").setValue("年份");
- sheet.getCellRange("A2").setValue("2017");
- sheet.getCellRange("A3").setValue("2018");
- sheet.getCellRange("A4").setValue("2019");
- sheet.getCellRange("A5").setValue("2020");
- sheet.getCellRange("B1").setValue("销售额");
- sheet.getCellRange("B2").setNumberValue(4000);
- sheet.getCellRange("B3").setNumberValue(6000);
- sheet.getCellRange("B4").setNumberValue(7000);
- sheet.getCellRange("B5").setNumberValue(8500);
- //设置单元格样式
- sheet.getCellRange("A1:B1").setRowHeight(15);
- sheet.getCellRange("A1:B1").getCellStyle().setColor(Color.darkGray);
- sheet.getCellRange("A1:B1").getCellStyle().getExcelFont().setColor(Color.white);
- sheet.getCellRange("A1:B1").getCellStyle().setVerticalAlignment(VerticalAlignType.Center);
- sheet.getCellRange("A1:B1").getCellStyle().setHorizontalAlignment(HorizontalAlignType.Center);
- sheet.getCellRange("B2:C5").getCellStyle().setNumberFormat("\"¥\"#,##0");
- //添加整体分离型饼图
- Chart piechart = sheet.getCharts().add(ExcelChartType.Pie);
- //设置图表数据区域
- piechart.setDataRange(sheet.getCellRange("B2:B5"));
- piechart.setSeriesDataFromRange(false);
- //设置图表位置
- piechart.setLeftColumn(4);
- piechart.setTopRow(1);
- piechart.setRightColumn(10);
- piechart.setBottomRow(20);
- //设置图表标题
- piechart.setChartTitle("年销售额");
- piechart.getChartTitleArea().isBold(true);
- piechart.getChartTitleArea().setSize(12);
- //设置系列标签
- ChartSerie cs = piechart.getSeries().get(0);
- cs.setCategoryLabels(sheet.getCellRange("A2:A5"));
- cs.setValues(sheet.getCellRange("B2:B5"));
- cs.getDataPoints().getDefaultDataPoint().getDataLabels().hasValue(true);
- piechart.getPlotArea().getFill().setVisible(false);
- //设置饼图整体分离
- for (int i = 0; i < piechart.getSeries().getCount(); i++)
- {
- piechart.getSeries().get(i).getDataFormat().setPercent(20);
- }
- //添加局部分离型饼图
- Chart piechart1 = sheet.getCharts().add(ExcelChartType.Pie);
- piechart1.setDataRange(sheet.getCellRange("B2:B5"));
- piechart1.setSeriesDataFromRange(false);
- piechart1.setLeftColumn(11);
- piechart1.setTopRow(1);
- piechart1.setRightColumn(17);
- piechart1.setBottomRow(20);
- piechart1.setChartTitle("年销售额");
- piechart1.getChartTitleArea().isBold(true);
- piechart1.getChartTitleArea().setSize(12);
- ChartSerie cs1 = piechart1.getSeries().get(0);
- cs1.setCategoryLabels(sheet.getCellRange("A2:A5"));
- cs1.setValues(sheet.getCellRange("B2:B5"));
- cs1.getDataPoints().getDefaultDataPoint().getDataLabels().hasValue(true);
- piechart1.getPlotArea().getFill().setVisible(false);
- //设置饼图局部分离
- piechart1.getSeries().get(0).getDataPoints().get(1).getDataFormat().setPercent(20);
- //保存文档
- workbook.saveToFile("ExplodedPieChart.xlsx", ExcelVersion.Version2016);
- workbook.dispose();
- }
- }
2. 分离型环形图
- import com.spire.xls.*;
- import com.spire.xls.charts.ChartSerie;
- import java.awt.*;
- public class ExplodedDoughnutChart {
- public static void main(String[] args) {
- //创建Workbook对象
- Workbook workbook = new Workbook();
- //获取第一个工作表
- Worksheet sheet = workbook.getWorksheets().get(0);
- //将图表数据写入工作表
- sheet.getCellRange("A1").setValue("年份");
- sheet.getCellRange("A2").setValue("2017");
- sheet.getCellRange("A3").setValue("2018");
- sheet.getCellRange("A4").setValue("2019");
- sheet.getCellRange("A5").setValue("2020");
- sheet.getCellRange("B1").setValue("销售额");
- sheet.getCellRange("B2").setNumberValue(4000);
- sheet.getCellRange("B3").setNumberValue(6000);
- sheet.getCellRange("B4").setNumberValue(7000);
- sheet.getCellRange("B5").setNumberValue(8500);
- //设置单元格样式
- sheet.getCellRange("A1:B1").setRowHeight(15);
- sheet.getCellRange("A1:B1").getCellStyle().setColor(Color.darkGray);
- sheet.getCellRange("A1:B1").getCellStyle().getExcelFont().setColor(Color.white);
- sheet.getCellRange("A1:B1").getCellStyle().setVerticalAlignment(VerticalAlignType.Center);
- sheet.getCellRange("A1:B1").getCellStyle().setHorizontalAlignment(HorizontalAlignType.Center);
- sheet.getCellRange("B2:C5").getCellStyle().setNumberFormat("\"¥\"#,##0");
- //添加饼图
- Chart chart = sheet.getCharts().add(ExcelChartType.Doughnut);
- //设置图表数据区域
- chart.setDataRange(sheet.getCellRange("B2:B5"));
- chart.setSeriesDataFromRange(false);
- //设置图表位置
- chart.setLeftColumn(4);
- chart.setTopRow(1);
- chart.setRightColumn(10);
- chart.setBottomRow(20);
- //设置图表标题
- chart.setChartTitle("年销售额");
- chart.getChartTitleArea().isBold(true);
- chart.getChartTitleArea().setSize(12);
- //设置系列标签
- ChartSerie cs = chart.getSeries().get(0);
- cs.setCategoryLabels(sheet.getCellRange("A2:A5"));
- cs.setValues(sheet.getCellRange("B2:B5"));
- cs.getDataPoints().getDefaultDataPoint().getDataLabels().hasValue(true);
- chart.getPlotArea().getFill().setVisible(false);
- //添加分离型饼图
- Chart chart1 = sheet.getCharts().add(ExcelChartType.DoughnutExploded);//分离型饼图
- chart1.setDataRange(sheet.getCellRange("B2:B5"));
- chart1.setSeriesDataFromRange(false);
- chart1.setLeftColumn(11);
- chart1.setTopRow(1);
- chart1.setRightColumn(17);
- chart1.setBottomRow(20);
- chart1.setChartTitle("年销售额");
- chart1.getChartTitleArea().isBold(true);
- chart1.getChartTitleArea().setSize(12);
- ChartSerie cs1 = chart1.getSeries().get(0);
- cs1.setCategoryLabels(sheet.getCellRange("A2:A5"));
- cs1.setValues(sheet.getCellRange("B2:B5"));
- cs1.getDataPoints().getDefaultDataPoint().getDataLabels().hasValue(true);
- chart1.getPlotArea().getFill().setVisible(false);
- //保存文档
- workbook.saveToFile("ExplodedDoughnutChart.xlsx",FileFormat.Version2013);
- workbook.dispose();
- }
- }
Java 在Excel中添加分离型饼图、环形图的更多相关文章
- java 在Excel中插入图片 POI实现
一.POI简介 Jakarta POI 是apache的子项目,目标是处理ole2对象.它提供了一组操纵Windows文档的Java API 目前比较成熟的是HSSF接口,处理MS Excel(97- ...
- Excel中添加并使用宏实现批量更新数据
一.状况描述 当我们需要后台更新大量数据的时候,可以使用该功能.二.解決方案 (1)新建一个Excel文件,并另存为启用宏的Excel工作簿,扩展名为.xlsm. (2)在Excel ...
- JAVA将Excel中的报表导出为图片格式(一)问题背景
如题所示,先抛出一个问题,如何使用JAVA将Excel中的报表导出为图片格式? 首先说一下这个问题的背景,也就是为什么博主会碰到这个问题 随着微信,易信之流大行其道,企业内部的办公交流.绩效考评甚至考 ...
- Java处理Excel中的日期格式
Java处理Excel中的日期格式 2011-12-23 17:34:03| 分类: java |举报 |字号 订阅 下载LOFTER 我的照片书 | 在Excel中的日期格式,其数值为距离1 ...
- JAVA将Excel中的报表导出为图片格式(三)换一种实现
上一篇介绍了使用Java的Robot机器人实现截图,然后将剪贴板上的数据流生成PNG图片 但是经过博主的不断测试,在完全依赖远程桌面的没有终端显示器的服务器上 使用截图方式是不可行的,因为一旦使用了远 ...
- Java 在Excel中添加水印(单一水印、平铺水印)
在Excel中没有直接添加水印的功能,但依旧可以通过一定方式来实现类似水印效果.本文通过Java程序代码介绍具体实现方法.可添加单一水印效果,即水印是以单个文本字样来呈现:也可添加多个平铺水印效果,即 ...
- Java实现Excel中的NORMSDIST函数和NORMSINV函数
由于工作中需要将Excel中的此两种函数转换成java函数,从而计算内部评级的资本占用率和资本占用金额.经过多方查阅资料和整理,总结出如下两个转换方法 标准正态分布累计函数NORMSDIST: pub ...
- java程序转换excel中科学记数法的数据为date类型
今天出于某些原因从mongodb数据库中导出了一些数据,为了更直观的发送给其他人查阅,便使用mongoVUE的导出为excel功能. 但是导出后出现了一个问题,里边有一列存储时间的,存储的是lon ...
- Eclipse中java向数据库中添加数据,更新数据,删除数据
前面详细写过如何连接数据库的具体操作,下面介绍向数据库中添加数据. 注意事项:如果参考下面代码,需要 改包名,数据库名,数据库账号,密码,和数据表(数据表里面的信息) package com.ning ...
随机推荐
- flex与bison的学习
获取bison http://www.gnu.org/software/bison 获取flex http://flex.sourceforge.net/ 本书的范例 ftp://ftp.iecc.c ...
- 释放至强平台 AI 加速潜能 汇医慧影打造全周期 AI 医学影像解决方案
基于英特尔架构实现软硬协同加速,显著提升新冠肺炎.乳腺癌等疾病的检测和筛查效率,并帮助医疗科研平台预防"维度灾难"问题 <PAGE 1 LEFT COLUMN: CUSTOM ...
- 腾讯云--对象存储cos绑定自定义域名
1.登录腾讯云控制台,找到对象存储一栏 2.选择一个你想绑定域名的存储桶 3.进入你选择的存储桶,点击域名管理 4.选择自定义源站域名.在域名处填写你要设置的自定义域名,在源站类型处选择静态网站源站, ...
- MyBatis源码解析
在讲解MyBatis之前,先说下传统JDBC连接数据库的弊端: 1.JDBC底层没有实现连接池,从而导致操作数据库需要频繁的创建和释放,影响性能: 2.JDBC的代码散落在Java代码中,如果需要修改 ...
- waitpid()系统调用学习
waitpid()的头文件 #include <sys/types.h> #include <sys/wait.h> pid_t waitpid(pid_t pid,int ...
- Kubernetes+Promethues+Cloud Alert实践分享
前言 容器集群管理系统 Kubernetes(简称K8s),为容器化的应用提供部署运行.容器编排.负载均衡.服务发现和动态伸缩等一系列完整功能,Prometheus 对 K8s 支持非常棒,能够自动发 ...
- TCP中RTT的测量和RTO的计算 以及 接收缓存大小的动态调整
RTT测量 在发送端有两种RTT的测量方法,但是因为TCP流控制是在接收端进行的,所以接收端也需要 有测量RTT的方法. /* Receiver "autotuning" code ...
- linux netfilter rule match target 数据结构
对于netfilter 可以参考 https://netfilter.org/documentation/HOWTO/netfilter-hacking-HOWTO-3.html netfilter ...
- 极客mysql01
1.MySQL的框架有几个组件, 各是什么作用?连接器:负责跟客户端建立连接.获取权限.维持和管理连接.查询缓存:查询请求先访问缓存(key 是查询的语句,value 是查询的结果).命中直接返回.不 ...
- 定制ubuntu的时候修改proseed
一个参数的修改 d-i clock-setup/utc-auto boolean false (不用utc) d-i clock-setup/ntp boolean false (不时间同步) d-i ...