C# 操作Excel数据透视表
一、概述
数据透视表(Pivot Table)是一种交互式的表,可以进行某些计算,如求和与计数等,可动态地改变透视表版面布置,也可以重新安排行号、列标和页字段。当改变版面布置时,数据透视表也会按照新的布置来进行更新,可以说是一个功能强大的数据分析工具。因此,本篇文章将介绍在C# 中关于Excel数据透视表的操作示例,示例内容主要包含以下要点:
1. 创建透视表
(1)创建数据缓存
(2)创建数据透视表
(3)添加行字段和列字段
(4)添加值字段
(5)设置样式
2. 设置行折叠、展开
3. 设置字段升序、降序
4. 删除透视表
二、准备工具
- Spire.XLS for .NET (可支持80余种Excel内置的数据透视表样式)
PS:安装后,注意在项目中引用Spire.XLS.dll再进行代码操作,dll文件在安装路径下的Bin文件夹中获取。
三、示例操作
1.创建透视表
C#
//创建一个Workbook类实例,并加载Excel文档 Workbook workbook = new Workbook(); workbook.LoadFromFile("test.xlsx"); //获取第一个工作表 Worksheet sheet = workbook.Worksheets[0]; //为需要汇总和分析的数据创建缓存 CellRange dataRange = sheet.Range["A1:D10"]; PivotCache cache = workbook.PivotCaches.Add(dataRange); //使用缓存创建数据透视表,并指定透视表的名称以及在工作表中的位置 PivotTable pivotTable = sheet.PivotTables.Add("PivotTable", sheet.Range["A12"], cache); //添加行字段 var r1 = pivotTable.PivotFields["月份"]; r1.Axis = AxisTypes.Row; var r2 = pivotTable.PivotFields["厂商"]; r2.Axis = AxisTypes.Row; //设置行字段的标题 pivotTable.Options.RowHeaderCaption = "月份"; //添加列字段 var col1 = pivotTable.PivotFields["产品"]; col1.Axis = AxisTypes.Column; //设置列字段的标题 pivotTable.Options.ColumnHeaderCaption = "产品"; //添加值字段 pivotTable.DataFields.Add(pivotTable.PivotFields["总产量"], "求和项:总产量", SubtotalTypes.Sum); //设置透视表的样式(Spire.XLS共支持80余种Excel内置的数据透视表样式) pivotTable.BuiltInStyle = PivotBuiltInStyles.PivotStyleDark13; //保存并打开文档 workbook.SaveToFile("数据透视表.xlsx", ExcelVersion.Version2013); System.Diagnostics.Process.Start("数据透视表.xlsx");
测试结果:
2. 设置行折叠、展开
C#
//创建Workbook类对象,加载Excel文档 Workbook workbook = new Workbook(); workbook.LoadFromFile("数据透视表.xlsx"); //获取数据透视表 XlsPivotTable pivotTable = workbook.Worksheets[0].PivotTables[0] as XlsPivotTable; //计算数据 pivotTable.CalculateData(); //展开”月份”字段下“2”的详细信息 (pivotTable.PivotFields["月份"] as Spire.Xls.Core.Spreadsheet.PivotTables.XlsPivotField).HideItemDetail("2", false); //折叠”月份”字段下“3”的详细信息 (pivotTable.PivotFields["月份"] as Spire.Xls.Core.Spreadsheet.PivotTables.XlsPivotField).HideItemDetail("3", true); //保存并打开文档 workbook.SaveToFile("折叠、展开行.xlsx", ExcelVersion.Version2013); System.Diagnostics.Process.Start("折叠、展开行.xlsx");
测试结果:
3. 设置字段排序
这里支持三种不同类型的排序,可根据需要选择相应的排序类型。
C#
//创建一个Workbook类对象,并加载Excel文档 Workbook workbook = new Workbook(); workbook.LoadFromFile("数据透视表.xlsx"); //获取数据透视表 Spire.Xls.Core.Spreadsheet.PivotTables.XlsPivotTable pivotTable = workbook.Worksheets[0].PivotTables[0] as Spire.Xls.Core.Spreadsheet.PivotTables.XlsPivotTable; //对指定字段进行升序排序 pivotTable.PivotFields[2].SortType = PivotFieldSortType.Ascending; //保存并打开文档 workbook.SaveToFile("升序.xlsx", ExcelVersion.Version2013); System.Diagnostics.Process.Start("升序.xlsx");
测试结果:
4. 删除透视表
删除透视表可通过以下两种方法:
- 根据透视表名称删除
- 根据透视表索引删除
//创建一个工作簿,并加载Excel文档 Workbook workbook = new Workbook(); workbook.LoadFromFile("数据透视表.xlsx"); //删除第一张工作表上名称为“PivotTable”的数据透视表 workbook.Worksheets[0].PivotTables.Remove("PivotTable"); //删除第一张工作表上索引为0即第一个数据透视表 //workbook.Worksheets[0].PivotTables.RemoveAt(0); //保存文档 workbook.SaveToFile("删除数据透视表.xlsx", ExcelVersion.Version2013);
测试结果:
以上内容为本次关于“Excel数据透视表的示例操作”的全部内容,欢迎转载(转载请注明出处)
感谢阅读!

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
JavaScript instanceof 运算符深入剖析
转自:https://www.ibm.com/developerworks/cn/web/1306_jiangjj_jsinstanceof/ instanceof 运算符简介 在 JavaScript 中,判断一个变量的类型尝尝会用 typeof 运算符,在使用 typeof 运算符时采用引用类型存储值会出现一个问题,无论引用的是什么类型的对象,它都返回 "object"。ECMAScript 引入了另一个 Java 运算符 instanceof 来解决这个问题。instanceof 运算符与 typeof 运算符相似,用于识别正在处理的对象的类型。与 typeof 方法不同的是,instanceof 方法要求开发者明确地确认对象为某特定类型。例如: 清单 1. instanceof 示例 1 2 var oStringObject = new String("hello world"); console.log(oStringObject instanceof String); // 输出 "true" 这段代码问的是“变量 oStringObject 是否为 String 对象的...
- 下一篇
集合Collection总览
前言 声明,本文使用的是JDK1.8 从今天开始正式去学习Java基础中最重要的东西--->集合 无论在开发中,在面试中这个知识点都是非常非常重要的,因此,我在此花费的时间也是很多,得参阅挺多的资料,下面未必就做到日更了... 当然了,如果讲得有错的地方还请大家多多包涵并不吝在评论去指正~ 一、集合(Collection)介绍 1.1为什么需要Collection Java是一门面向对象的语言,就免不了处理对象 为了方便操作多个对象,那么我们就得把这多个对象存储起来 想要存储多个对象(变量),很容易就能想到一个容器 常用的容器我们知道有-->StringBuffered,数组(虽然有对象数组,但是数组的长度是不可变的!) 所以,Java就为我们提供了集合(Collection)~ 1.2数组和集合的区别 接下来,我们可以对数组和集合的区别来分析一下: 数组和集合的区别: 1:长度的区别 数组的长度固定 集合的长度可变 2:内容不容 数组存储的是同一种类型的元素 集合可以存储不同类型的元素(但是一般我们不这样干..) 3:元素的数据类型 数组可以存储基本数据类型,也可以存储引...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- 设置Eclipse缩进为4个空格,增强代码规范
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- SpringBoot2全家桶,快速入门学习开发网站教程
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- MySQL8.0.19开启GTID主从同步CentOS8
- Red5直播服务器,属于Java语言的直播服务器
- CentOS7,8上快速安装Gitea,搭建Git服务器
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7
- CentOS6,CentOS7官方镜像安装Oracle11G