Java 创建、刷新Excel透视表/设置透视表行折叠、展开
透视表是依据已有数据源来创建的交互式表格,我们可在excel中创建透视表,也可编辑已有透视表。本文以创建透视表、刷新透视表以及设置透视表的行展开或折叠为例,介绍具体的操作方法。
所需工具:Free Spire.XLS for Java免费版,编辑代码前,先下载导入jar到Java程序(可手动 下载导入,或通过 Maven仓库下载导入)。
示例代码
1. 创建透视表
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(); } }
2. 刷新透视表
import com.spire.xls.*; public class RefreshPivotTable { public static void main(String[] args) { //创建实例,加载Excel Workbook wb = new Workbook(); wb.loadFromFile("数据透视表.xlsx"); //获取第一个工作表 Worksheet sheet = wb.getWorksheets().get(0); //更改透视表的数据源数据 sheet.getCellRange("C2:C4").setText("产品A"); sheet.getCellRange("C5:C7").setText("产品B"); sheet.getCellRange("C8:C10").setText("产品C"); //获取透视表,刷新数据 PivotTable pivotTable = (PivotTable) sheet.getPivotTables().get(0); pivotTable.getCache().isRefreshOnLoad(); //保存文档 wb.saveToFile("刷新透视表.xlsx",FileFormat.Version2013); } }
透视表更新前后效果:
3. 折叠、展开透视表中的行
import com.spire.xls.*; import com.spire.xls.core.spreadsheet.pivottables.XlsPivotTable; public class ExpandRows { public static void main(String[] args) { //加载包含透视表的Excel Workbook wb = new Workbook(); wb.loadFromFile("数据透视表.xlsx"); //获取数据透视表 XlsPivotTable pivotTable = (XlsPivotTable) wb.getWorksheets().get(0).getPivotTables().get(0); //计算数据 pivotTable.calculateData(); //展开”月份”字段下“2”的详细信息 PivotField field = (PivotField) pivotTable.getPivotFields().get("月份"); field.hideItemDetail("2",false); //折叠”月份”字段下“3”的详细信息 PivotField field1 = (PivotField) pivotTable.getPivotFields().get("月份"); field1.hideItemDetail("3",true); //保存并打开文档 wb.saveToFile("展开、折叠行.xlsx", ExcelVersion.Version2013); wb.dispose(); } }
折叠、展开效果:
分类:
Java Excel
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· DeepSeek “源神”启动!「GitHub 热点速览」
· 我与微信审核的“相爱相杀”看个人小程序副业
· 上周热点回顾(2.17-2.23)
· 如何使用 Uni-app 实现视频聊天(源码,支持安卓、iOS)
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)