色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

Java 在Excel中添加分離型餅圖、環形圖的方法

瀏覽:179日期:2022-05-25 15:39:47

一、概述

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(); }}

Java 在Excel中添加分離型餅圖、環形圖的方法

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中添加分離型餅圖、環形圖的方法的詳細內容,更多關于Java excel添加圖表的資料請關注好吧啦網其它相關文章!

標簽: excel
相關文章:
主站蜘蛛池模板: 不卡一级aaa全黄毛片 | 国产在线播放免费 | 久久精品国产免费中文 | 欧美成人免费一区在线播放 | 成年18网站免费视频网站 | 精品欧美高清一区二区免费 | 黄色片日本人 | 精品在线一区二区 | 成人免费手机在线看网站 | 欧美日韩精品国产一区二区 | 加勒比一本一道在线 | 美女张开腿让男人操 | 欧美片网站免费 | 日韩毛片久久91 | 欧美精品亚洲一区二区在线播放 | 国产老鸭窝毛片一区二区 | 97视频在线视频 | 在线视频观看一区 | 免费的毛片 | a毛片基地免费全部香蕉 | 香港经典a毛片免费观看爽爽影院 | 亚洲黄色成人 | 亚洲美女视频在线观看 | 中文字幕av一区二区三区 | 国产精品6 | 日韩欧美在线播放视频 | 亚洲最大情网站在线观看 | 国产视频中文字幕 | 亚洲 欧美 国产 日韩 制服 bt | 国产免费午夜a无码v视频 | 免费观看欧美精品成人毛片 | 国产精品国产三级国产专区5o | 2022国产91精品久久久久久 | 久久久久在线观看 | 久草在线新首页 | 国产精品96久久久久久久 | 欧美孕妇性xxxⅹ精品hd | 性欧美精品孕妇 | 中文字幕在线乱码不卡区区 | 狠狠色丁香婷婷综合小时婷婷 | 欧美兽皇video |