美文网首页Java
使用Java给现有Excel工作表创建、刷新数据透视表

使用Java给现有Excel工作表创建、刷新数据透视表

作者: Tina_Tang | 来源:发表于2020-09-01 17:05 被阅读0次

数据透视表的定义及用处

数据透视表(Pivot Table)是一种对大量数据快速汇总和建立交叉关系的交互式动态表格,能帮助用户分析和组织数据。例如,计算平均值、标准差、计算百分比、建立新的数据子集等。

本文将通过使用免费Spire.XLS for Java类库来介绍如何在Java程序中给现有Excel工作表创建和刷新数据透视表。

测试环境搭建

● Intellij Idea2019.1

● JDK 1.8.0

● Spire.Xls.jar

Jar包获取及导入:

方式1通过官网下载Free Spire.XLS for Java产品包,解压后将lib文件夹下的Spire.Xls.jar手动导入IDEA中。具体导入方式见下图:

方式2创建一个Maven应用程序,在pom.xml文件中配置Maven仓库路径及指定Spire.XLS for Java的Maven依赖。

<repositories> 

 <repository>

 <id>com.e-iceblue</id> 

<url>http://repo.e-iceblue.cn/repository/maven-public/</url> 

 </repository> 

 </repositories> 

 <dependencies> 

 <dependency>

 <groupId>e-iceblue </groupId>

 <artifactId>spire.xls.free</artifactId> 

 <version>2.2.0</version>

 </dependency> 

 </dependencies>

配置完成后,在IDEA中,您需点击"Import Changes"即可导入JAR包;在Eclipse中,则需要点击"Save"按钮。

代码示例

示例1:创建数据透视表

import com.spire.xls.*;

public class CreatePivotTable {

public static void main(String[] args) {

//加载示例文档

Workbook workbook = new Workbook();

workbook.loadFromFile("C:\\Users\\Test1\\Desktop\\Sample.xlsx");

//获取第一个工作表

Worksheet sheet = workbook.getWorksheets().get(0);

//为需要汇总和创建分析的数据创建缓存

CellRange dataRange = sheet.getCellRange("A1:C17");

PivotCache cache = workbook.getPivotCaches().add(dataRange);

//使用缓存创建数据透视表,并指定透视表的名称以及在工作表中的位置

PivotTable pt = sheet.getPivotTables().add("Pivot Table", sheet.getCellRange("E10"), cache);

//添加行字段

PivotField pf=null;

if (pt.getPivotFields().get("季度") instanceof PivotField){

pf= (PivotField) pt.getPivotFields().get("季度");

        }

pf.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.PivotStyleMedium12);

//保存文档

workbook.saveToFile("output/CreatePivotTable.xlsx", ExcelVersion.Version2013);

    }

}

创建效果:

示例2:刷新数据透视表

默认情况下,数据源的更改变动不会自动更新到透视表,需要在透视表上进行刷新才能显示最新数据变化。

import com.spire.xls.*;

public class RefreshPivotTable {

public static void main(String[] args) {

//创建实例,加载Excel

Workbook wb = new Workbook();

wb.loadFromFile("C:\\Users\\Test1\\Desktop\\CreatePivotTable.xlsx");

//获取第一个工作表

Worksheet sheet = wb.getWorksheets().get(0);

//更改透视表的数据源数据

sheet.getCellRange("B5").setText("扫地机器人");

sheet.getCellRange("B9").setText("扫地机器人");

sheet.getCellRange("B13").setText("扫地机器人");

sheet.getCellRange("B17").setText("扫地机器人");

//获取透视表,刷新数据

PivotTable pivotTable = (PivotTable) sheet.getPivotTables().get(0);

pivotTable.getCache().isRefreshOnLoad();

//保存文档

wb.saveToFile("output/RefreshPivotTable.xlsx",FileFormat.Version2013);

    }

}

刷新效果:

相关文章

  • 使用Java给现有Excel工作表创建、刷新数据透视表

    数据透视表的定义及用处 数据透视表(Pivot Table)是一种对大量数据快速汇总和建立交叉关系的交互式动态表格...

  • Day21数据透视表

    数据透视表-基本介绍四点 创建数据透视表、数据透视表的整理、转换为普通表格、刷新所有数据透视表 在对数据透视表处理...

  • 认识数据透视表

    数据透视表及图表数据透视表-基本介绍学习要点1、创建数据透视表 2、数据透视表的整理 3、转换为普通表格 4、刷新...

  • 2018-09-16

    数据透视表-基本介绍学习要点 1、创建数据透视表 2、数据透视表的整理 3、转换为普通表格 4、刷新所有数据透视表...

  • Excel第六讲:认识数据透视表

    1、Excel创建数据透视表:选中任意一个单元格——插入——数据透视表——右击数据透视表选项--显示——勾选“经典...

  • 数据透视表

    一、目录: 数据透视表-基本介绍学习要点 1、创建数据透视表 2、数据透视表的整理 3、转换为普通表格 4、刷新所...

  • 数据透视表-第9节

    创建数据透视表 创建数据透视表1.jpg 认识透视表工具 1.数据透视表字段 2.数据透视表使用 3.调节数据透视...

  • 33、数据透视表的特殊用法2018-10-25

    一、跨表格生成数据透视表 1、插入数据透视表——新工作表/现有工作表 备注:非同工作簿也可以插入数据透视表 二、生...

  • 2018-12-03数据透视表

    基本介绍学习要点 1、创建数据透视表 2、数据透视表的整理 3、转换为普通表格 4、刷新所有数据透视表 一,数据透...

  • 21-17 数据透视表创建流程及布局美化

    一、基本流程 1)创建数据透视表 2)数据透视表的整理 3)转换为普通表格 4)刷新所有数据透视表 二、布局美化 ...

网友评论

    本文标题:使用Java给现有Excel工作表创建、刷新数据透视表

    本文链接:https://www.haomeiwen.com/subject/hqivsktx.html