java基于poi导出excel透视表代码实例

 更新时间:2019年12月20日 09:01:26   作者:骑码闯天涯  
这篇文章主要介绍了java基于poi导出excel透视表代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

这篇文章主要介绍了java基于poi导出excel透视表代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

从前,我是一个前端程序猿,怀着对打通任(前)督(后)二(开)脉(发)的梦想转了后端,自学两礼拜java+spring全家桶,直接上项目实战。最近接到一需求:将业务数据导出一张透视表。

需求开发完成已近有一段时间了,甲方的大爷大妈,爷爷奶奶们也都用的很开心,我也很开心,于是就心想咱学了也不能白学,所以写下这篇随笔。

先看下用easypoi+POI导出的excel效果图(easypoi用来导出sheet1数据源,poi用来sheet0透视表):

图中的excel分为两个sheet, sheet1是数据源,sheet0是根据sheet的数据生成的透视表。代码如下:

// 利用esaypoi生成excel数据,即sheet1里面的数据
Workbook workbook = ExcelExportUtil.exportExcel(new ExportParams(null, "sheet1", ExcelType.XSSF), pojoClass, list);
    Sheet sheet1 = workbook.getSheetAt(0);
    sheet1.setDefaultColumnWidth(50 * 256);
    sheet1.setDefaultRowHeight((short)(2 * 256));

    // 创建数据透视sheet
    XSSFSheet pivotSheet = (XSSFSheet )workbook.createSheet();
    pivotSheet.setDefaultColumnWidth(50 * 256);

    // 获取数据sheet的总行数
    int num = sheet1.getLastRowNum();
    // 数据透视表数据源的起点单元格位置
    CellReference topLeft = new CellReference("A1");
    // 数据透视表数据源的终点单元格位置
    CellReference botRight = new CellReference(("M"+num));
    // 数据透视表生产的起点单元格位置
    CellReference ptStartCell = new CellReference("A1");
    AreaReference areaR = new AreaReference(topLeft, botRight);
    XSSFPivotTable pivotTable = pivotSheet.createPivotTable(areaR, ptStartCell, sheet1);
    // 添加行标签
    pivotTable.addRowLabel(4); // 部门
    pivotTable.addRowLabel(1); // 科目
    pivotTable.addRowLabel(0); // 借贷方向
    pivotTable.addRowLabel(11); // 单据编号
    pivotTable.addRowLabel(12); // 凭证编号
    pivotTable.addRowLabel(9); // 付款编码
    pivotTable.addRowLabel(10); // 付款时间
    pivotTable.addColumnLabel(DataConsolidateFunction.SUM, 3, "分录金额");
    // 将透视表的列以表格的样式显示 这个地方弄了好久
    int count = 13; // count为数据源的列的数量
    for (int i = 0; i < count; i++) {
      CTPivotField ctPivotField = pivotTable.getCTPivotTableDefinition().getPivotFields().getPivotFieldArray(i);
      ctPivotField.setOutline(false);
    }

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

相关文章

  • 用JAVA实现杨辉三角实例

    用JAVA实现杨辉三角实例

    大家好,本篇文章主要讲的是用JAVA实现杨辉三角实例,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下
    2022-01-01
  • IDEA整合Dubbo+Zookeeper+SpringBoot实现

    IDEA整合Dubbo+Zookeeper+SpringBoot实现

    初学者,想自己动手做一个简单的demo,本文主要介绍了IDEA整合Dubbo+Zookeeper+SpringBoot实现,需要的朋友们下面随着小编来一起学习学习吧
    2021-06-06
  • 详解 Java 中 equals 和 == 的区别

    详解 Java 中 equals 和 == 的区别

    这篇文章主要介绍了详解 Java 中 equals 和 == 的区别的相关资料,equals 和 == 都是用来检测两个字符串是否相等,返回值也都是布尔型,但是两者在内部比较的处理中却不尽相同需要的朋友可以参考下
    2017-03-03
  • 解决SpringBoot整合ElasticSearch遇到的连接问题

    解决SpringBoot整合ElasticSearch遇到的连接问题

    这篇文章主要介绍了解决SpringBoot整合ElasticSearch遇到的连接问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-08-08
  • mybatis的insert语句插入数据时的返回值的实现

    mybatis的insert语句插入数据时的返回值的实现

    这篇文章主要介绍了mybatis的insert语句插入数据时的返回值的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-10-10
  • 手把手教你如何用JAVA连接MYSQL(mysql-connector-j-8.0.32.jar)

    手把手教你如何用JAVA连接MYSQL(mysql-connector-j-8.0.32.jar)

    这篇文章主要介绍了关于如何用JAVA连接MYSQL(mysql-connector-j-8.0.32.jar)的相关资料,文中通过图文介绍的非常详细,对大家学习或者使用MySQL具有一定的参考借鉴价值,需要的朋友可以参考下
    2024-01-01
  • Java Collections.EMPTY_LIST与Collections.emptyList()的区别

    Java Collections.EMPTY_LIST与Collections.emptyList()的区别

    这篇文章主要介绍了Java Collections.EMPTY_LIST与Collections.emptyList()的区别,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-11-11
  • Springboot项目使用拦截器方法详解

    Springboot项目使用拦截器方法详解

    这篇文章主要介绍了Springboot项目使用拦截器方法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-09-09
  • Java数组与字符串深入探索使用方法

    Java数组与字符串深入探索使用方法

    在今天的文章中,我将为你详细讲述Java学习中重要的一节 [ 数组与字符串 ] ,带你深入了解Java语言中数组的声明、创建和初始化方法,字符串的定义以及常用到的操作方法
    2022-07-07
  • java实现拉钩网上的FizzBuzzWhizz问题示例

    java实现拉钩网上的FizzBuzzWhizz问题示例

    这篇文章主要介绍了java实现拉钩网上的FizzBuzzWhizz问题示例,需要的朋友可以参考下
    2014-05-05

最新评论