Java 在 Excel 中創建餅圖/環形圖


餅圖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);
    }
}

 

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM