zoukankan      html  css  js  c++  java
  • 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);
        }
    }

     

  • 相关阅读:
    linux 消息队列
    linux 共享内存
    多线程(八)~ThreadLocal、InheritableThreadLocal的使用
    多线程(四)~数据操作的原子性,使用原子性操作AutomicInteger替换非原子性的i++的操作
    多线程(五)~ wait/notify机制(等待/通知)
    多线程(六)~通过管道进行线程之间的通信:字节流、字符流
    多线程(二)~Thread类相关的API介绍
    多线程(三)~多线程中数据的可见性-volatile关键字
    多线程(一)~基础介绍,简单demo实现
    haproxy学习——安装(一)
  • 原文地址:https://www.cnblogs.com/jazz-z/p/13099141.html
Copyright © 2011-2022 走看看