电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

瀏覽:212日期: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
相關文章:
主站蜘蛛池模板: 深圳市索富通实业有限公司-可燃气体报警器 | 可燃气体探测器 | 气体检测仪 | 托利多电子平台秤-高精度接线盒-托利多高精度电子秤|百科 | 磁力链接搜索神器_BT磁力狗_CILIMAO磁力猫_高效磁力搜索引擎2024 | 卓能JOINTLEAN端子连接器厂家-专业提供PCB接线端子|轨道式端子|重载连接器|欧式连接器等电气连接产品和服务 | 起好名字_取个好名字_好名网免费取好名在线打分 | 蓝米云-专注于高性价比香港/美国VPS云服务器及海外公益型免费虚拟主机 | 广东恩亿梯电源有限公司【官网】_UPS不间断电源|EPS应急电源|模块化机房|电动汽车充电桩_UPS电源厂家(恩亿梯UPS电源,UPS不间断电源,不间断电源UPS) | 沈阳真空机_沈阳真空包装机_沈阳大米真空包装机-沈阳海鹞真空包装机械有限公司 | 氧化铁红厂家-淄博宗昂化工 | 低合金板|安阳低合金板|河南低合金板|高强度板|桥梁板_安阳润兴 北京租车牌|京牌指标租赁|小客车指标出租 | 预制舱-电力集装箱预制舱-模块化预制舱生产厂家-腾达电器设备 | 科箭WMS仓库管理软件-TMS物流管理系统-科箭SaaS云服务 | 低温柔性试验仪-土工布淤堵-沥青车辙试验仪-莱博特(天津)试验机有限公司 | 深圳诚暄fpc首页-柔性线路板,fpc柔性线路板打样生产厂家 | 淄博不锈钢无缝管,淄博不锈钢管-鑫门物资有限公司 | 【北京写字楼出租_写字楼租赁_办公室出租网/出售】-远行地产官网 | 中国品牌门窗网_中国十大门窗品牌_著名门窗品牌 | 新疆十佳旅行社_新疆旅游报价_新疆自驾跟团游-新疆中西部国际旅行社 | 盘装氧量分析仪-防爆壁挂氧化锆分析仪-安徽吉帆仪表有限公司 | 剪刃_纵剪机刀片_分条机刀片-南京雷德机械有限公司 | 全自动贴标机-套标机-工业热风机-不干胶贴标机-上海厚冉机械 | 福州仿石漆加盟_福建仿石漆厂家-外墙仿石漆加盟推荐铁壁金钢(福建)新材料科技有限公司有保障 | 真空泵厂家_真空泵机组_水环泵_旋片泵_罗茨泵_耐腐蚀防爆_中德制泵 | 西点培训学校_法式西点培训班_西点师培训_西点蛋糕培训-广州烘趣西点烘焙培训学院 | 德国进口电锅炉_商用电热水器_壁挂炉_电采暖器_电热锅炉[德国宝] | 聚氨酯保温钢管_聚氨酯直埋保温管道_聚氨酯发泡保温管厂家-沧州万荣防腐保温管道有限公司 | 防渗膜厂家|养殖防渗膜|水产养殖防渗膜-泰安佳路通工程材料有限公司 | 飞歌臭氧发生器厂家_水处理臭氧发生器_十大臭氧消毒机品牌 | 精密钢管,冷拔精密无缝钢管,精密钢管厂,精密钢管制造厂家,精密钢管生产厂家,山东精密钢管厂家 | 山东氧化铁红,山东铁红-淄博科瑞化工有限公司 | 切铝机-数控切割机-型材切割机-铝型材切割机-【昆山邓氏精密机械有限公司】 | 四合院设计_四合院装修_四合院会所设计-四合院古建设计与建造中心1 | 外观设计_设备外观设计_外观设计公司_产品外观设计_机械设备外观设计_东莞工业设计公司-意品深蓝 | 诚暄电子公司首页-线路板打样,pcb线路板打样加工制作厂家 | 阻垢剂,反渗透阻垢剂,缓蚀阻垢剂-山东普尼奥水处理科技有限公司 真空粉体取样阀,电动楔式闸阀,电动针型阀-耐苛尔(上海)自动化仪表有限公司 | 定做大型恒温循环水浴槽-工业用不锈钢恒温水箱-大容量低温恒温水槽-常州精达仪器 | 防水试验机_防水测试设备_防水试验装置_淋雨试验箱-广州岳信试验设备有限公司 | 温泉机设备|温泉小镇规划设计|碳酸泉设备 - 大连连邦温泉科技 | 医养体检包_公卫随访箱_慢病随访包_家签随访包_随访一体机-济南易享医疗科技有限公司 | 路面机械厂家| 双吸泵,双吸泵厂家,OS双吸泵-山东博二泵业有限公司 |