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解决No enclosing instance of type PrintListFromTailToHead
这篇文章主要介绍了Java解决No enclosing instance of type PrintListFromTailToHead is accessible问题的两种方案的相关资料,需要的朋友可以参考下2016-07-07Java中的常用时间日期类总结(Date、DateFormat)
在Java开发中处理时间和日期是相当常见的任务,无论是计算日期差异、格式化日期显示、解析日期字符串还是进行日期计算,都需要一些时间和日期处理的技巧,这篇文章主要给大家介绍了关于Java中常用时间日期类(Date、DateFormat)的相关资料,需要的朋友可以参考下2024-08-08
最新评论