Java在Excel中创建透视表方法解析

 更新时间:2020年05月18日 09:59:33   作者:E-iceblue  
这篇文章主要介绍了Java在Excel中创建透视表方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

本文内容介绍通过Java程序在Excel表格中根据数据来创建透视表。

环境准备

需要使用Excel类库工具—Free Spire.XLS for Java,这里使用的是免费版,可通过官网下载Jar包并解压,手动导入lib文件夹下的Spire.Xls.jar到Java程序;或者也可以通过Maven仓库下载导入

Java代码示例

import com.spire.xls.*;

public class CreatePivotTable {
  public static void main(String[] args) {
    //加载Excel测试文档
    Workbook wb = new Workbook();
    wb.loadFromFile("test.xlsx");

    //获取第一个的工作表
    Worksheet sheet = wb.getWorksheets().get(0);

    //为需要汇总和分析的数据创建缓存
    CellRange dataRange = sheet.getCellRange("A1:D10");
    PivotCache cache = wb.getPivotCaches().add(dataRange);

    //使用缓存创建数据透视表,并指定透视表的名称以及在工作表中的位置
    PivotTable pt = sheet.getPivotTables().add("PivotTable",sheet.getCellRange("A12"),cache);

    //添加行字段1
    PivotField pf1 = null;
    if (pt.getPivotFields().get("月份") instanceof PivotField){
      pf1 = (PivotField) pt.getPivotFields().get("月份");
    }
    pf1.setAxis(AxisTypes.Row);

    //添加行字段2
    PivotField pf2 = null;
    if (pt.getPivotFields().get("厂商") instanceof PivotField){
      pf2 = (PivotField) pt.getPivotFields().get("厂商");
    }
    pf2.setAxis(AxisTypes.Row);
    //设置行字段的标题
    pt.getOptions().setRowHeaderCaption("月份");

    //添加列字段
    PivotField pf3 = null;
    if (pt.getPivotFields().get("产品") instanceof PivotField){
      pf3 = (PivotField) pt.getPivotFields().get("产品");
    }
    pf3.setAxis(AxisTypes.Column);
    //设置列字段标题
    pt.getOptions().setColumnHeaderCaption("产品");

    //添加值字段
    pt.getDataFields().add(pt.getPivotFields().get("总产量"),"求和项:总产量",SubtotalTypes.Sum);

    //设置透视表样式
    pt.setBuiltInStyle(PivotBuiltInStyles.PivotStyleDark12);

    //保存文档
    wb.saveToFile("数据透视表.xlsx", ExcelVersion.Version2013);
    wb.dispose();
  }
}

结果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Java利用ElasticSearch实现自动补全功能

    Java利用ElasticSearch实现自动补全功能

    这篇文章主要为大家详细介绍了Java如何利用ElasticSearch实现跟谷歌和百度类似的下拉补全提示功能,文中的示例代码讲解详细,需要的可以参考一下
    2023-08-08
  • SpringBoot基于Swagger2构建API文档过程解析

    SpringBoot基于Swagger2构建API文档过程解析

    这篇文章主要介绍了SpringBoot基于Swagger2构建API文档过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-11-11
  • Spring中@Async的使用小结

    Spring中@Async的使用小结

    在Java开发中,我们常常会遇到需要执行耗时操作的场景,例如文件上传、网络请求等,本文将介绍如何在Java中使用异步方法,并探讨其中的一些注意事项,感兴趣的朋友跟随小编一起看看吧
    2024-01-01
  • springboot与dubbo的版本匹配问题

    springboot与dubbo的版本匹配问题

    这篇文章主要介绍了springboot与dubbo的版本匹配问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-10-10
  • java过滤器中Filter的ChainFilter过滤链

    java过滤器中Filter的ChainFilter过滤链

    这篇文章主要介绍了java过滤器中Filter的ChainFilter过滤链,发送请求时,如果有不符合的信息将会被filter进行拦截,如果符合则会进行放行。如果感兴趣可以来学习一下
    2020-07-07
  • idea如何生成springboot单元测试用例

    idea如何生成springboot单元测试用例

    这篇文章主要介绍了idea生成springboot单元测试用例,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-08-08
  • Java中如何自定义一个类加载器

    Java中如何自定义一个类加载器

    这篇文章主要介绍了Java中如何自定义一个类加载器,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • 对数据进行分页显示到table中的实现方法

    对数据进行分页显示到table中的实现方法

    这篇文章主要介绍了对数据进行分页显示到table中的实现方法的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-05-05
  • 构建多模块的Spring Boot项目步骤全纪录

    构建多模块的Spring Boot项目步骤全纪录

    这篇文章主要给大家介绍了关于如何构建多模块的Spring Boot项目的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用SpringBoot具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-05-05
  • Springboot整合logback多节点日志文件加端口号区分的操作方法

    Springboot整合logback多节点日志文件加端口号区分的操作方法

    这篇文章主要介绍了Springboot整合logback多节点日志文件加端口号区分的操作方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-09-09

最新评论