【原创】.NET读写Excel工具Spire.Xls使用(4)对数据操作与控制-程序员宅基地

技术标签: c#  

                本博客所有文章分类的总目录:http://www.cnblogs.com/asxinyu/p/4288836.html

.NET读写Excel工具Spire.Xls使用文章目录:http://www.cnblogs.com/asxinyu/p/4374032.html

  Spire.Office for .NET是E-iceblue开发的一种企业级.NET Office编辑的软件集合,包括Spire.Doc,Spire XLS,Spire.PDF,Spire.BarCode等等。.NET平台的开发人员可以使用Spire.Office for .NET轻松的操作含有文档编辑功能的应用程序,还可以导出为MS Word/Excel/RTF/Acces、PDF、XPS、HTML、XML等格式,使用Spire.Office,不需要安装Microsoft Office。虽然Spire.Office for .NET是商业产品,但它的每一个基础功能组件都提供了免费版本。可以去官网看看:http://www.e-iceblue.com/。虽然有一些限制,但简单的东西还是可以试一试。本文介绍的Spire.XLS只是Spire.Office下面的一个操作Excel的组件。

  前一篇文章:“.NET读写Excel工具Spire.Xls使用(3)单元格控制 ”给大家介绍了Spire.XLS的中单元格的格式等控制功能,这篇文章将重点介绍C#操作Excel文件时,对数据的控制。单元格和数据是Excel文件的核心,很难将两者单独分开讲解或者学习,有时候都是交叉的。所以这篇文章的内容有一部分在前一篇文章中其实已经说过了,例如单元格数据的编辑修改,这里就不再重复讲解。

1.Excel行分组显示

  在数据很多的时候,有时候需要进行分组显示,可以隐藏很多细节。在需要的时候再点击看详细的内容,相当于明细表吧。当然可能也不一定是这样。总之就是Excel表的分组功能,就像下面这个样子,注意看 行号 的变化,中间行号的行分组隐藏起来的:

下面看看如何使用Spire.XLS来在程序中设置分组操作,其实也非常简单,这就是商业组件的好处,把功能做到细致,1个函数就实现想要的功能,使用的是sheet对象的GroupByRows方法,如下面例子:

复制代码
1 static void ExcelTest6()
2 {
3     Workbook workbook = new Workbook();
4     //获取第一个sheet,进行操作,下标是从0开始
5     Worksheet sheet = workbook.Worksheets[0];
6     sheet.GroupByRows(2, 9, true);//最后1个bool参数是默认是否折叠
7     workbook.SaveToFile("Sample.xls", ExcelVersion.Version97to2003);
8     System.Diagnostics.Process.Start("Sample.xls");
9 }
复制代码

效果如下,把第2-9行分组,默认是折叠的:

2.向单元格快速填充数组

   在前一篇文章中,我们都是直接向单元格写入数据,这个想起来也很繁琐,所以我也会想能不能直接一次性将数组全部写入,这些岂不是更快更方便,代码也更少。在查看Spire.XLS的官方案例的时候,还真发现了这么个功能,非常强大,对于导入数据非常管用:直接在指定位置插入二维数组,批量操作,省去了逐个单元格操作的烦恼。看看下面代码:

复制代码
 1 static void ExcelTest7()
 2 {
 3     Workbook workbook = new Workbook();
 4     workbook.CreateEmptySheets(1);
 5     Worksheet sheet = workbook.Worksheets[0];
 6 
 7     int maxRow = 10;
 8     int maxCol = 5;
 9     //生成测试数据数组
10     object[,] myarray = new object[maxRow + 1, maxCol + 1];
11     bool[,] isred = new bool[maxRow + 1, maxCol + 1];
12     for (int i = 0; i <= maxRow; i++)
13     {
14         for (int j = 0; j <= maxCol; j++)
15         {
16             myarray[i, j] = i + j;
17             if ((int)myarray[i, j] > 8)
18                 isred[i, j] = true;
19         }
20     }
21     //将数组插入到sheet中,后面参数是起始的行和列号
22     sheet.InsertArray(myarray, 1, 1);
23 
24     workbook.SaveToFile("test.xls");
25     System.Diagnostics.Process.Start("test.xls");
26 }
复制代码

 效果如下图所示,截图不完整。。。反正就是这个意思,当然你还可以写入其他格式的数据:

3.查找与替换数据

   在处理大量的数据的时候,Excel中sheet的查找与替换是很常见的,平时虽然手动操作比较多,程序操作是怎么样的呢?其实也很简单,对sheet对象进行搜索,使用FindAllXXX方法找到相应的单元格即可,注意XXX代表不同的数据类型,如FindAllBool,FindAllDateTime,FindAllNumber,FindAllString等等。看一个例子演示如何直接进行查找和替换,并修改对应单元格颜色的例子:

复制代码
1 CellRange[] ranges = sheet.FindAllString("test", false, false);
2 //循环找到的单元格
3 foreach (CellRange range in ranges)
4 {
5     range.Text = "修改后";
6     range.Style.Color = Color.Yellow;
7 }
复制代码

 4.数据过滤器创建与取消

  过滤器是啥玩意,可能一般人不会注意,当然经常使用Excel的人,过滤器是必不可少的。就是将列进行筛选,自动列出选项,然后操作者根据需要选择选项,显示指定条件的数据,相当于一个动态查询的过程吧。Excel的速度很快,很方便,就是下面这种效果:

 

实际的代码也很简单,如下面的代码,看方法的原型就知道啥意思了。选择表和范围,设置样式就可以了。

复制代码
1 Workbook workbook = new Workbook();
2 workbook.LoadFromFile("test.xlsx");
3 Worksheet sheet = workbook.Worksheets[0];
4 //创建过滤器
5 sheet.ListObjects.Create("Table", sheet.Range[1, 1, sheet.LastRow, sheet.LastColumn]);
6 
7 sheet.ListObjects[0].BuiltInTableStyle = TableBuiltInStyles.TableStyleLight9;
8 
9 workbook.SaveToFile("Filter.xlsx", ExcelVersion.Version2010);
复制代码

 当然,有时候也需要取消过滤器,需要过滤器只需要一个下面一个清空操作即可:

sheet.AutoFilters.Clear();


本文转自数据之巅博客园博客,原文链接:http://www.cnblogs.com/asxinyu/p/Spire_XLS_4_Data_Set.html,如需转载请自行联系原作者
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_33815613/article/details/90130169

智能推荐

jdk32位连不上oracle64位,64位 jdk 读取32位dll-程序员宅基地

文章浏览阅读227次。执行上面的测试代码,发现使用 32 位的 JDK 通过配置的 testodbc 数据源 (32 位的驱动程序)能够正常的连接到 64 位的数据库,如下图所示。 这个场景并不完全真实,只是我个人的一个联想和猜测,中间极有可能出 现不正确或不完整的......在 face.h 的头文件中包含了 jni.h 头 文件,所以需要将 jdk 安装目录下 include 文件夹下的 jni.h 头文件和 in..._32位jdk连不上数据库

迄今为止最强大的开源 LLM,15 万亿 Token 预训练的 LLaMA3 强势来袭_如何解决llama3 token长度问题-程序员宅基地

文章浏览阅读607次,点赞19次,收藏18次。例如,虽然 8B 参数模型在 Chinchilla 的最佳训练计算量对应于约 200B 个Token,但我们发现,即使在模型训练完成之后,再接受了两个数量级以上的数据训练,模型性能仍在继续提高。此版本是在 15 万亿个 Token 上预训练的语言模型,具有 8B 和 70B 两种参数规模,可以支持广泛的用户场景,在各种行业基准上取得了最先进的性能,并提供一些了新功能,包括改进的推理能力,这些都是同时期最好的开源模型。此外,还进行了广泛的实验,以评估在最终预训练数据集中混合不同来源的数据的最佳方法。_如何解决llama3 token长度问题

svn命令使用总结_svn删除文件夹命令-程序员宅基地

文章浏览阅读347次。Ubuntu安装svnapt-get install subversiongit工具使用ubuntu 18.04下svn的安装与基本命令_svn删除文件夹命令

Linux 机器间配置 SSH 免密登录_从linux服务器上ssh连接其他主机免输密码-程序员宅基地

文章浏览阅读1.4k次。在日常工作中,服务器常常会有多台。特别是应用服务器存在多台的情况下,在每台机器手动部署或升级服务,每次登录多台机器特别麻烦,通过一台机器跳转每次输入密码(一般都是超强密码)也麻烦。所以说配置机器间的免密,对日常工作来说可以简化操作流程,节省宝贵时间。这篇就简单说说如何配置多台机器间的免密功能。_从linux服务器上ssh连接其他主机免输密码

python预测值和真实值_机器学习中用什么图可以表示预测数据与真实数据的差异?...-程序员宅基地

文章浏览阅读2.5k次。但是实际上学习机器学习可能很困难。您要么使用行为类似于“黑匣子”的预构建包,要么在其中传递数据,另一端则产生魔力,或者您必须处理高级数学和线性代数。每种方法都使学习机器学习充满挑战和威胁。用Python搭建机器学习模型预测房租价格旨在向您介绍机器学习的基本概念。在继续学习时,您将从头开始构建第一个模型以进行预测,同时准确地了解模型的工作原理。(用Python搭建机器学习模型预测房租价格基于我们的机..._python机器学习预测数据比较作图

端口扫描--zmap-程序员宅基地

文章浏览阅读1k次。ZMap被设计用来针对整个IPv4地址空间或其中的大部分实施综合扫描的工具。ZMap是研究者手中的利器,但在运行ZMap时,请注意,您很有 可能正在以每秒140万个包的速度扫描整个IPv4地址空间 。我们建议用户即使在实施小范围扫描之前,也联系一下本地网络的管理员并参考我们列举的最佳扫描体验。默认情况下,ZMap会对于指定端口实施尽可能大速率的TCP SYN扫描。较为保守的情况下,对..._zmap输出结果带端口

随便推点

【计算机毕设文章】基于微信小程序的电子竞技信息交流 平台的设计与实现-程序员宅基地

文章浏览阅读31次。毕业论文(设计)题目(中文):基于微信小程序的电子竞技信息交流平台的设计与实现姓 名 学 号 院 (系) 专业、年级 指导教师2021年5月6日目 录1 绪 论 11.1课题研究背景 11.2设计原则 11.3研究内容 22系统关键技术 32.1 微信小程序 32.2微信Web开发者工具 32.3微信小程序API接口 32.4 WXML 、WXS、JS小程序编写语言 32.5 MYSQL数据库 43系统分析 53.1可行性分析 53.1.1

java https请求,https请求如何调用-程序员宅基地

文章浏览阅读1.1w次,点赞9次,收藏28次。https请求如何在代码中调用

单指令周期CPU---转移指令的实现_指令jal执行后下一条指令的地址为多-程序员宅基地

文章浏览阅读1.1w次,点赞6次,收藏37次。单周期MIPS_指令jal执行后下一条指令的地址为多

Java解析XML_java 解析xml-程序员宅基地

文章浏览阅读1k次,点赞17次,收藏23次。XML现在已经成为一种通用的数据交换格式,平台的无关性使得很多场合都需要用到XML。本文将详细介绍用Java解析XML的四种方法在做一般的XML数据交换过程中,我更乐意传递XML字符串,而不是格式化的XML Document。这就涉及到XML字符串和Xml Document的转换问题,说白了这是个很简单的问题,本文就各种XML解析器分别列举如下,以方便自己今后查阅。=========..._java 解析xml

【AI视野·今日NLP 自然语言处理论文速览 第二十期】Thu, 8 Jul 2021_自然语言处理最新论文-程序员宅基地

文章浏览阅读301次。AI视野·今日CS.NLP 自然语言处理论文速览Thu, 8 Jul 2021Totally 25 papers????上期速览更多精彩请移步主页Daily Computation and Language PapersDORA: Toward Policy Optimization for Task-oriented Dialogue System with Efficient Context Authors Hyunmin Jeon, Gary Geunbae Lee最近,通过_自然语言处理最新论文

Delphi XE 取得当前时间戳的几个函数_delphi时间戳-程序员宅基地

文章浏览阅读501次,点赞11次,收藏9次。时间戳 delphi_delphi时间戳

推荐文章

热门文章

相关标签