餅圖是Excel中常見的一種圓餅形圖表工具,它能夠直接以圖形的方式展現各個組成部分在整體中所占的比例,從而幫助我們更加快速直觀的去分析和理解抽象的資料,而環形圖則是餅圖的一種變形,在視覺上,環形圖去掉了中心的部分,但其主要功能依舊是詮釋資料間的占比關系,本文將介紹如何借助Free Spire.XLS for Java使用代碼在Excel檔案中創建餅圖和環形圖,
基本步驟:
1. 下載Free Spire.XLS for Java包并解壓縮,
2. 將lib檔案夾下的Spire.Xls.jar包作為依賴項匯入到Java應用程式中,(也可直接通過Maven倉庫安裝JAR包(配置pom.xml檔案的代碼見下文))
3. 在Java應用程式中新建一個Java Class(此處我命名為CreatePieChart 和 CreateDoughnutChart), 然后輸入相應的Java代碼并運行,
配置pom.xml檔案:
<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>2.2.0</version>
</dependency>
</dependencies>
餅圖:
import com.spire.xls.*; import com.spire.xls.charts.ChartSerie; import java.awt.*; public class CreatePieChart { 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("2002"); sheet.getCellRange("A3").setValue("2003"); sheet.getCellRange("A4").setValue("2004"); sheet.getCellRange("A5").setValue("2005"); 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.Pie); //設定圖表資料區域 chart.setDataRange(sheet.getCellRange("B2:B5")); chart.setSeriesDataFromRange(false); //設定圖表位置 chart.setLeftColumn(3); chart.setTopRow(1); chart.setRightColumn(11); 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); //保存檔案 workbook.saveToFile("餅圖.xlsx", ExcelVersion.Version2016); } }

環形圖:
import com.spire.xls.*; import com.spire.xls.charts.ChartSerie; import com.spire.xls.charts.ChartSeries; import java.awt.*; public class CreateDoughnutChart { 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("成都"); sheet.getCellRange("A3").setValue("武漢"); sheet.getCellRange("A4").setValue("上海"); sheet.getCellRange("A5").setValue("北京"); sheet.getCellRange("B1").setValue("銷售額"); sheet.getCellRange("B2").setNumberValue(6000); sheet.getCellRange("B3").setNumberValue(8000); sheet.getCellRange("B4").setNumberValue(9000); 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("A1:B5")); chart.setSeriesDataFromRange(false); //設定圖表位置 chart.setLeftColumn(3); chart.setTopRow(1); chart.setRightColumn(11); chart.setBottomRow(20); //設定圖表標題 chart.setChartTitle("市場占比"); chart.getChartTitleArea().isBold(true); chart.getChartTitleArea().setSize(12); //設定系列的顏色 ChartSeries series = chart.getSeries(); for (int i = 0 ; i < series.size() ; i++) { ChartSerie cs = series.get(i); cs.getDataPoints().getDefaultDataPoint().getDataLabels().hasPercentage(true); } //設定圖例的位置 chart.getLegend().setPosition(LegendPositionType.Top); //保存檔案 workbook.saveToFile("環形圖.xlsx", ExcelVersion.Version2016); } }

轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/164442.html
標籤:Java
