一、概述

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路径及依赖,参考如下:

  1. <repositories>
  2. <repository>
  3. <id>com.e-iceblue</id>
  4. <url>http://repo.e-iceblue.cn/repository/maven-public/</url>
  5. </repository>
  6. </repositories>
  7. <dependencies>
  8. <dependency>
  9. <groupId>e-iceblue</groupId>
  10. <artifactId>spire.xls.free</artifactId>
  11. <version>3.9.1</version>
  12. </dependency>
  13. </dependencies>

配置完成后,导入jar到程序。

三、Java代码

1. 分离型饼图

  1. import com.spire.xls.*;
  2. import com.spire.xls.charts.ChartSerie;
  3.  
  4. import java.awt.*;
  5.  
  6. public class ExplodedPieChart {
  7. public static void main(String[] args) {
  8. //创建Workbook对象
  9. Workbook workbook = new Workbook();
  10.  
  11. //获取第一个工作表
  12. Worksheet sheet = workbook.getWorksheets().get(0);
  13.  
  14. //将图表数据写入工作表
  15. sheet.getCellRange("A1").setValue("年份");
  16. sheet.getCellRange("A2").setValue("2017");
  17. sheet.getCellRange("A3").setValue("2018");
  18. sheet.getCellRange("A4").setValue("2019");
  19. sheet.getCellRange("A5").setValue("2020");
  20.  
  21. sheet.getCellRange("B1").setValue("销售额");
  22. sheet.getCellRange("B2").setNumberValue(4000);
  23. sheet.getCellRange("B3").setNumberValue(6000);
  24. sheet.getCellRange("B4").setNumberValue(7000);
  25. sheet.getCellRange("B5").setNumberValue(8500);
  26.  
  27. //设置单元格样式
  28. sheet.getCellRange("A1:B1").setRowHeight(15);
  29. sheet.getCellRange("A1:B1").getCellStyle().setColor(Color.darkGray);
  30. sheet.getCellRange("A1:B1").getCellStyle().getExcelFont().setColor(Color.white);
  31. sheet.getCellRange("A1:B1").getCellStyle().setVerticalAlignment(VerticalAlignType.Center);
  32. sheet.getCellRange("A1:B1").getCellStyle().setHorizontalAlignment(HorizontalAlignType.Center);
  33. sheet.getCellRange("B2:C5").getCellStyle().setNumberFormat("\"¥\"#,##0");
  34.  
  35. //添加整体分离型饼图
  36. Chart piechart = sheet.getCharts().add(ExcelChartType.Pie);
  37. //设置图表数据区域
  38. piechart.setDataRange(sheet.getCellRange("B2:B5"));
  39. piechart.setSeriesDataFromRange(false);
  40. //设置图表位置
  41. piechart.setLeftColumn(4);
  42. piechart.setTopRow(1);
  43. piechart.setRightColumn(10);
  44. piechart.setBottomRow(20);
  45. //设置图表标题
  46. piechart.setChartTitle("年销售额");
  47. piechart.getChartTitleArea().isBold(true);
  48. piechart.getChartTitleArea().setSize(12);
  49. //设置系列标签
  50. ChartSerie cs = piechart.getSeries().get(0);
  51. cs.setCategoryLabels(sheet.getCellRange("A2:A5"));
  52. cs.setValues(sheet.getCellRange("B2:B5"));
  53. cs.getDataPoints().getDefaultDataPoint().getDataLabels().hasValue(true);
  54. piechart.getPlotArea().getFill().setVisible(false);
  55.  
  56. //设置饼图整体分离
  57. for (int i = 0; i < piechart.getSeries().getCount(); i++)
  58. {
  59. piechart.getSeries().get(i).getDataFormat().setPercent(20);
  60. }
  61.  
  62. //添加局部分离型饼图
  63. Chart piechart1 = sheet.getCharts().add(ExcelChartType.Pie);
  64. piechart1.setDataRange(sheet.getCellRange("B2:B5"));
  65. piechart1.setSeriesDataFromRange(false);
  66. piechart1.setLeftColumn(11);
  67. piechart1.setTopRow(1);
  68. piechart1.setRightColumn(17);
  69. piechart1.setBottomRow(20);
  70. piechart1.setChartTitle("年销售额");
  71. piechart1.getChartTitleArea().isBold(true);
  72. piechart1.getChartTitleArea().setSize(12);
  73. ChartSerie cs1 = piechart1.getSeries().get(0);
  74. cs1.setCategoryLabels(sheet.getCellRange("A2:A5"));
  75. cs1.setValues(sheet.getCellRange("B2:B5"));
  76. cs1.getDataPoints().getDefaultDataPoint().getDataLabels().hasValue(true);
  77. piechart1.getPlotArea().getFill().setVisible(false);
  78. //设置饼图局部分离
  79. piechart1.getSeries().get(0).getDataPoints().get(1).getDataFormat().setPercent(20);
  80.  
  81. //保存文档
  82. workbook.saveToFile("ExplodedPieChart.xlsx", ExcelVersion.Version2016);
  83. workbook.dispose();
  84. }
  85. }

2. 分离型环形图

  1. import com.spire.xls.*;
  2. import com.spire.xls.charts.ChartSerie;
  3.  
  4. import java.awt.*;
  5.  
  6. public class ExplodedDoughnutChart {
  7. public static void main(String[] args) {
  8. //创建Workbook对象
  9. Workbook workbook = new Workbook();
  10.  
  11. //获取第一个工作表
  12. Worksheet sheet = workbook.getWorksheets().get(0);
  13.  
  14. //将图表数据写入工作表
  15. sheet.getCellRange("A1").setValue("年份");
  16. sheet.getCellRange("A2").setValue("2017");
  17. sheet.getCellRange("A3").setValue("2018");
  18. sheet.getCellRange("A4").setValue("2019");
  19. sheet.getCellRange("A5").setValue("2020");
  20. sheet.getCellRange("B1").setValue("销售额");
  21. sheet.getCellRange("B2").setNumberValue(4000);
  22. sheet.getCellRange("B3").setNumberValue(6000);
  23. sheet.getCellRange("B4").setNumberValue(7000);
  24. sheet.getCellRange("B5").setNumberValue(8500);
  25.  
  26. //设置单元格样式
  27. sheet.getCellRange("A1:B1").setRowHeight(15);
  28. sheet.getCellRange("A1:B1").getCellStyle().setColor(Color.darkGray);
  29. sheet.getCellRange("A1:B1").getCellStyle().getExcelFont().setColor(Color.white);
  30. sheet.getCellRange("A1:B1").getCellStyle().setVerticalAlignment(VerticalAlignType.Center);
  31. sheet.getCellRange("A1:B1").getCellStyle().setHorizontalAlignment(HorizontalAlignType.Center);
  32. sheet.getCellRange("B2:C5").getCellStyle().setNumberFormat("\"¥\"#,##0");
  33.  
  34. //添加饼图
  35. Chart chart = sheet.getCharts().add(ExcelChartType.Doughnut);
  36. //设置图表数据区域
  37. chart.setDataRange(sheet.getCellRange("B2:B5"));
  38. chart.setSeriesDataFromRange(false);
  39. //设置图表位置
  40. chart.setLeftColumn(4);
  41. chart.setTopRow(1);
  42. chart.setRightColumn(10);
  43. chart.setBottomRow(20);
  44. //设置图表标题
  45. chart.setChartTitle("年销售额");
  46. chart.getChartTitleArea().isBold(true);
  47. chart.getChartTitleArea().setSize(12);
  48.  
  49. //设置系列标签
  50. ChartSerie cs = chart.getSeries().get(0);
  51. cs.setCategoryLabels(sheet.getCellRange("A2:A5"));
  52. cs.setValues(sheet.getCellRange("B2:B5"));
  53. cs.getDataPoints().getDefaultDataPoint().getDataLabels().hasValue(true);
  54. chart.getPlotArea().getFill().setVisible(false);
  55.  
  56. //添加分离型饼图
  57. Chart chart1 = sheet.getCharts().add(ExcelChartType.DoughnutExploded);//分离型饼图
  58. chart1.setDataRange(sheet.getCellRange("B2:B5"));
  59. chart1.setSeriesDataFromRange(false);
  60. chart1.setLeftColumn(11);
  61. chart1.setTopRow(1);
  62. chart1.setRightColumn(17);
  63. chart1.setBottomRow(20);
  64. chart1.setChartTitle("年销售额");
  65. chart1.getChartTitleArea().isBold(true);
  66. chart1.getChartTitleArea().setSize(12);
  67. ChartSerie cs1 = chart1.getSeries().get(0);
  68. cs1.setCategoryLabels(sheet.getCellRange("A2:A5"));
  69. cs1.setValues(sheet.getCellRange("B2:B5"));
  70. cs1.getDataPoints().getDefaultDataPoint().getDataLabels().hasValue(true);
  71. chart1.getPlotArea().getFill().setVisible(false);
  72.  
  73. //保存文档
  74. workbook.saveToFile("ExplodedDoughnutChart.xlsx",FileFormat.Version2013);
  75. workbook.dispose();
  76. }
  77. }

Java 在Excel中添加分离型饼图、环形图的更多相关文章

  1. java 在Excel中插入图片 POI实现

    一.POI简介 Jakarta POI 是apache的子项目,目标是处理ole2对象.它提供了一组操纵Windows文档的Java API 目前比较成熟的是HSSF接口,处理MS Excel(97- ...

  2. Excel中添加并使用宏实现批量更新数据

    一.状况描述    当我们需要后台更新大量数据的时候,可以使用该功能.二.解決方案    (1)新建一个Excel文件,并另存为启用宏的Excel工作簿,扩展名为.xlsm.    (2)在Excel ...

  3. JAVA将Excel中的报表导出为图片格式(一)问题背景

    如题所示,先抛出一个问题,如何使用JAVA将Excel中的报表导出为图片格式? 首先说一下这个问题的背景,也就是为什么博主会碰到这个问题 随着微信,易信之流大行其道,企业内部的办公交流.绩效考评甚至考 ...

  4. Java处理Excel中的日期格式

    Java处理Excel中的日期格式 2011-12-23 17:34:03|  分类: java |举报 |字号 订阅 下载LOFTER 我的照片书  |   在Excel中的日期格式,其数值为距离1 ...

  5. JAVA将Excel中的报表导出为图片格式(三)换一种实现

    上一篇介绍了使用Java的Robot机器人实现截图,然后将剪贴板上的数据流生成PNG图片 但是经过博主的不断测试,在完全依赖远程桌面的没有终端显示器的服务器上 使用截图方式是不可行的,因为一旦使用了远 ...

  6. Java 在Excel中添加水印(单一水印、平铺水印)

    在Excel中没有直接添加水印的功能,但依旧可以通过一定方式来实现类似水印效果.本文通过Java程序代码介绍具体实现方法.可添加单一水印效果,即水印是以单个文本字样来呈现:也可添加多个平铺水印效果,即 ...

  7. Java实现Excel中的NORMSDIST函数和NORMSINV函数

    由于工作中需要将Excel中的此两种函数转换成java函数,从而计算内部评级的资本占用率和资本占用金额.经过多方查阅资料和整理,总结出如下两个转换方法 标准正态分布累计函数NORMSDIST: pub ...

  8. java程序转换excel中科学记数法的数据为date类型

    今天出于某些原因从mongodb数据库中导出了一些数据,为了更直观的发送给其他人查阅,便使用mongoVUE的导出为excel功能.   但是导出后出现了一个问题,里边有一列存储时间的,存储的是lon ...

  9. Eclipse中java向数据库中添加数据,更新数据,删除数据

    前面详细写过如何连接数据库的具体操作,下面介绍向数据库中添加数据. 注意事项:如果参考下面代码,需要 改包名,数据库名,数据库账号,密码,和数据表(数据表里面的信息) package com.ning ...

随机推荐

  1. flex与bison的学习

    获取bison http://www.gnu.org/software/bison 获取flex http://flex.sourceforge.net/ 本书的范例 ftp://ftp.iecc.c ...

  2. 释放至强平台 AI 加速潜能 汇医慧影打造全周期 AI 医学影像解决方案

    基于英特尔架构实现软硬协同加速,显著提升新冠肺炎.乳腺癌等疾病的检测和筛查效率,并帮助医疗科研平台预防"维度灾难"问题 <PAGE 1 LEFT COLUMN: CUSTOM ...

  3. 腾讯云--对象存储cos绑定自定义域名

    1.登录腾讯云控制台,找到对象存储一栏 2.选择一个你想绑定域名的存储桶 3.进入你选择的存储桶,点击域名管理 4.选择自定义源站域名.在域名处填写你要设置的自定义域名,在源站类型处选择静态网站源站, ...

  4. MyBatis源码解析

    在讲解MyBatis之前,先说下传统JDBC连接数据库的弊端: 1.JDBC底层没有实现连接池,从而导致操作数据库需要频繁的创建和释放,影响性能: 2.JDBC的代码散落在Java代码中,如果需要修改 ...

  5. waitpid()系统调用学习

    waitpid()的头文件 #include <sys/types.h>  #include <sys/wait.h> pid_t waitpid(pid_t pid,int ...

  6. Kubernetes+Promethues+Cloud Alert实践分享

    前言 容器集群管理系统 Kubernetes(简称K8s),为容器化的应用提供部署运行.容器编排.负载均衡.服务发现和动态伸缩等一系列完整功能,Prometheus 对 K8s 支持非常棒,能够自动发 ...

  7. TCP中RTT的测量和RTO的计算 以及 接收缓存大小的动态调整

    RTT测量 在发送端有两种RTT的测量方法,但是因为TCP流控制是在接收端进行的,所以接收端也需要 有测量RTT的方法. /* Receiver "autotuning" code ...

  8. linux netfilter rule match target 数据结构

    对于netfilter 可以参考 https://netfilter.org/documentation/HOWTO/netfilter-hacking-HOWTO-3.html netfilter ...

  9. 极客mysql01

    1.MySQL的框架有几个组件, 各是什么作用?连接器:负责跟客户端建立连接.获取权限.维持和管理连接.查询缓存:查询请求先访问缓存(key 是查询的语句,value 是查询的结果).命中直接返回.不 ...

  10. 定制ubuntu的时候修改proseed

    一个参数的修改 d-i clock-setup/utc-auto boolean false (不用utc) d-i clock-setup/ntp boolean false (不时间同步) d-i ...