【原创】.NET读写Excel工具Spire.Xls使用(4)对数据操作与控制
.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() 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行分组,默认是折叠的:
在前一篇文章中,我们都是直接向单元格写入数据,这个想起来也很繁琐,所以我也会想能不能直接一次性将数组全部写入,这些岂不是更快更方便,代码也更少。在查看Spire.XLS的官方案例的时候,还真发现了这么个功能,非常强大,对于导入数据非常管用:直接在指定位置插入二维数组,批量操作,省去了逐个单元格操作的烦恼。看看下面代码:
1 static void ExcelTest7() 3 Workbook workbook = new Workbook(); 4 workbook.CreateEmptySheets(1); 5 Worksheet sheet = workbook.Worksheets[0]; 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++) 14 for (int j = 0; j = maxCol; j++) 16 myarray[i, j] = i + j; 17 if ((int)myarray[i, j] 8) 18 isred[i, j] = true; 21 //将数组插入到sheet中,后面参数是起始的行和列号 22 sheet.InsertArray(myarray, 1, 1); 24 workbook.SaveToFile("test.xls"); 25 System.Diagnostics.Process.Start("test.xls"); 26 }
效果如下图所示,截图不完整。。。反正就是这个意思,当然你还可以写入其他格式的数据:
在处理大量的数据的时候,Excel中sheet的查找与替换是很常见的,平时虽然手动操作比较多,程序操作是怎么样的呢?其实也很简单,对sheet对象进行搜索,使用FindAllXXX方法找到相应的单元格即可,注意XXX代表不同的数据类型,如FindAllBool,FindAllDateTime,FindAllNumber,FindAllString等等。看一个例子演示如何直接进行查找和替换,并修改对应单元格颜色的例子:
1 CellRange[] ranges = sheet.FindAllString("test", false, false); 2 //循环找到的单元格 3 foreach (CellRange range in ranges) 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]); 7 sheet.ListObjects[0].BuiltInTableStyle = TableBuiltInStyles.TableStyleLight9; 9 workbook.SaveToFile("Filter.xlsx", ExcelVersion.Version2010);
当然,有时候也需要取消过滤器,需要过滤器只需要一个下面一个清空操作即可:
sheet.AutoFilters.Clear();
.net core工具组件系列之Redis—— 第一篇:Windows环境配置Redis(5.x以上版本)以及部署为Windows服务 Cygwin工具编译Redis Redis6.x版本是未编译版本(官方很调皮,所以没办法,咱只好帮他们编译一下了),所以咱们先下载一个Cygwin,用它来对Redis进行编译。
.net core工具组件系列之Autofac—— 第一篇:Autofac系列Autofac的几种常见注册方式、生命周期和AOP 使用Autofac进行服务注册实践:新建三个项目,分别是webapi项目 Wesky.Core.Autofac以及两个类库项目 Wesky.Core.Interface和Wesky.Core.Service。在Webapi项目下,引用Autofac的三个包:Autofac、Autofac.Configuration和Autofac.Extensions.DependencyInjection 。
使用.NET开发一个屏幕OCR工具 本文将介绍使用.NET开发的一款桌面截图 OCR 工具,软件已开源,地址:[https://github.com/sangyuxiaowu/Snipping_OCR](https://github.com/sangyuxiaowu/Snipping_OCR)
.Net脱壳工具 de4dot参数说明/简易教程 原文:.Net脱壳工具 de4dot参数说明/简易教程 de4dot /? 帮助原文 使用方法 de4dot d:\xx.exe -p xc -p xc 指定壳类型 , 这里是xc,表示Xenocode壳.
相关文章
- 【原创】.NET读写Excel工具Spire.Xls使用(2)Excel文件的控制
- C# ASP.NET FILEUPLOAD详解
- .NET 开源Protobuf-net从入门到精通
- .NET常用类库--苏飞合集
- Asp.Net Web API 2第十七课——Creating an OData Endpoint in ASP.NET Web API 2(OData终结点)
- asp.net中导出excel数据的方法汇总
- 微软.NET Framework cve-2017-8759 复现
- ASP.NET MVC - The view must derive from WebViewPage, or WebViewPage<TModel>
- 对象池在 .NET (Core)中的应用[2]: 设计篇
- [ASP.NET Core 3框架揭秘] Options[2]: 配置选项的正确使用方式[下篇]
- [转] Asp.Net 导出 Excel 数据的9种方案
- 【原创】.NET读写Excel工具Spire.Xls使用(5)重量级的Excel图表功能
- 【原创】.NET读写Excel工具Spire.Xls使用(3)单元格控制
- 【原创】.NET读写Excel工具Spire.Xls使用(2)Excel文件的控制
- Atitit ..Net Framework sdk 3.0 3.5 4.04.5 4.6 4.7 .net core版本新特性 v2 s22 1. 新特性来源于 down ms 官方网站1
- Atitit.excel导出 功能解决方案 php java C#.net版总集合.doc
- Atitit 文件上传 架构设计 实现机制 解决方案 实践java php c#.net js javascript c++ python
- Atitit.导出excel报表的设计与实现java .net php 总
- Atitit.导出excel报表的设计与实现java .net php 总结
- atitit.导出excel的设计----查询结果 导出为excel的实现java .net php 总结
- Spire.Office for .NET 7.11.0 冬季之约好时光~@~
- 〖Python自动化办公篇⑫〗- Excel 文件自动化 - 读取 excel 数据
- openpose_net随机搜索网络源代码
- Castle.Net 基本应用
- .Net——使用.net内置处理程序处理自己定义节点Demo
- excel根据颜色赋值 Excel填充颜色单元格替换成数字 excel把所有红色变成1
- VB.NET版机房收费系统---导出Excel表格
- 三分钟学会.NET微服务之Polly
- asp.net core webapi Session 内存缓存
- Aspose.OCR 22.11.1 for .NET Crack
- HttpClient 调用WebAPI时—传参的三种方式(ASP.NET MVC&CORE均适用)
- 〖Python自动化办公篇⑫〗- Excel 文件自动化 - 读取 excel 数据
- 〖Python自动化办公篇⑬〗- Excel 文件自动化 - 写入 excel 数据(xlsxwriter)
- Excel 2016 突然打开别人发过来的2个excel文件就关闭打不开,打开电脑上其他excel文件正常