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);
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持无名。
同类资源
- 超级列表框+文本EXCEL_导入导出模块V1.5
超级列表框+文本EXCEL_导入导出模块V1.5本文件感兴趣的可以参考一下。...
- Excel批量排序置行高置列宽
易语言Excel批量排序置行高置列宽例子源代码,批量设置序号,批量设置行高或者批量设置列宽。...
- 易语言可以直接声明内存DLL的导出函数
易语言可以直接声明内存DLL的导出函数例子源代码,源码缺的就几个API,而且常用的那种,就这样你就看不出来了。...
- QQ好友提取源码,支持分组提取高效导出
易语言QQ好友提取源码,支持分组提取高效导出例子源代码,附件内带源码欢迎学习。...
- 完美的超级列表框EXCEL导入导出,支持任意列,自动读取表头,自动调整列宽
易语言完美的超级列表框EXCEL导入导出,支持任意列,自动读取表头,自动调整列宽例子源代码,为方便使用已封装成...
- 内存加载dll运行导出函数
易语言内存加载dll运行导出函数例子源代码,很简单的,没什么技术,代码全在截图里面了。...
- Java支持库多线程调用不崩溃
易语言Java支持库多线程调用不崩溃例子源代码,Java支持库多线程调用方法。...
- PC端微信图片批量解密、查看、删除、导出工具WxDatViewer 1.5
如果长期在电脑上打开微信,会带来一个灾难性的后果,那就是微信图片文件夹会急剧膨胀,短短几天内甚至可以达到...
- 文件流字节集方式直接写Excel文件
易语言文件流字节集方式直接写Excel文件例子源代码,本人只做了写文本格式WriteString的函数。...
- 数据库导出为Excel可设置边框、底色等效果
易语言数据库导出为Excel可设置边框、底色等效果例子源代码,搞了个数据库里直接导出Excel的小功能,感觉挺实...
- EXCEL快速导入导出,增加数据库直接导出及文件格式支持
易语言EXCEL快速导入导出,增加数据库直接导出及文件格式支持例子源代码,系统自带的工作簿速度实在是太慢了,...
- 基于javaweb的个人网站的毕业设计,包含毕业答辩的PPT文件
基于javaweb的个人网站的毕业设计,包含毕业答辩的PPT文件本文件感兴趣的可以参考一下。...