.NET读写Excel工具Spire.Xls使用 对数据操作与控制(4)
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是商业产品,但它的每一个基础功能组件都提供了免费版本。可以去官网看看:。虽然有一些限制,但简单的东西还是可以试一试。本文介绍的spire.xls只是spire.office下面的一个操作excel的组件。
前一篇文章:“.net读写excel工具spire.xls使用(3)单元格控制 ”给大家介绍了spire.xls的中单元格的格式等控制功能,这篇文章将重点介绍c#操作excel文件时,对数据的控制。单元格和数据是excel文件的核心,很难将两者单独分开讲解或者学习,有时候都是交叉的。所以这篇文章的内容有一部分在前一篇文章中其实已经说过了,例如单元格数据的编辑修改,这里就不再重复讲解。
1.excel行分组显示
在数据很多的时候,有时候需要进行分组显示,可以隐藏很多细节。在需要的时候再点击看详细的内容,相当于明细表吧。当然可能也不一定是这样。总之就是excel表的分组功能,就像下面这个样子,注意看 行号 的变化,中间行号的行分组隐藏起来的:
下面看看如何使用spire.xls来在程序中设置分组操作,其实也非常简单,这就是商业组件的好处,把功能做到细致,1个函数就实现想要的功能,使用的是sheet对象的groupbyrows方法,如下面例子:
static void exceltest6() { workbook workbook = new workbook(); //获取第一个sheet,进行操作,下标是从0开始 worksheet sheet = workbook.worksheets[0]; sheet.groupbyrows(2, 9, true);//最后1个bool参数是默认是否折叠 workbook.savetofile("sample.xls", excelversion.version97to2003); system.diagnostics.process.start("sample.xls"); }
效果如下,把第2-9行分组,默认是折叠的:
2.向单元格快速填充数组
在前一篇文章中,我们都是直接向单元格写入数据,这个想起来也很繁琐,所以我也会想能不能直接一次性将数组全部写入,这些岂不是更快更方便,代码也更少。在查看spire.xls的官方案例的时候,还真发现了这么个功能,非常强大,对于导入数据非常管用:直接在指定位置插入二维数组,批量操作,省去了逐个单元格操作的烦恼。看看下面代码:
static void exceltest7() { workbook workbook = new workbook(); workbook.createemptysheets(1); worksheet sheet = workbook.worksheets[0]; int maxrow = 10; int maxcol = 5; //生成测试数据数组 object[,] myarray = new object[maxrow + 1, maxcol + 1]; bool[,] isred = new bool[maxrow + 1, maxcol + 1]; for (int i = 0; i <= maxrow; i++) { for (int j = 0; j <= maxcol; j++) { myarray[i, j] = i + j; if ((int)myarray[i, j] > 8) isred[i, j] = true; } } //将数组插入到sheet中,后面参数是起始的行和列号 sheet.insertarray(myarray, 1, 1); workbook.savetofile("test.xls"); system.diagnostics.process.start("test.xls"); }
效果如下图所示,截图不完整。。。反正就是这个意思,当然你还可以写入其他格式的数据:
3.查找与替换数据
在处理大量的数据的时候,excel中sheet的查找与替换是很常见的,平时虽然手动操作比较多,程序操作是怎么样的呢?其实也很简单,对sheet对象进行搜索,使用findallxxx方法找到相应的单元格即可,注意xxx代表不同的数据类型,如findallbool,findalldatetime,findallnumber,findallstring等等。看一个例子演示如何直接进行查找和替换,并修改对应单元格颜色的例子:
cellrange[] ranges = sheet.findallstring("test", false, false); //循环找到的单元格 foreach (cellrange range in ranges) { range.text = "修改后"; range.style.color = color.yellow; }
4.数据过滤器创建与取消
过滤器是啥玩意,可能一般人不会注意,当然经常使用excel的人,过滤器是必不可少的。就是将列进行筛选,自动列出选项,然后操作者根据需要选择选项,显示指定条件的数据,相当于一个动态查询的过程吧。excel的速度很快,很方便,就是下面这种效果:
实际的代码也很简单,如下面的代码,看方法的原型就知道啥意思了。选择表和范围,设置样式就可以了。
workbook workbook = new workbook(); workbook.loadfromfile("test.xlsx"); worksheet sheet = workbook.worksheets[0]; //创建过滤器 sheet.listobjects.create("table", sheet.range[1, 1, sheet.lastrow, sheet.lastcolumn]); sheet.listobjects[0].builtintablestyle = tablebuiltinstyles.tablestylelight9; workbook.savetofile("filter.xlsx", excelversion.version2010);
当然,有时候也需要取消过滤器,需要过滤器只需要一个下面一个清空操作即可:
sheet.autofilters.clear();
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。