.NET讀寫(xiě)Excel工具Spire.Xls使用 對(duì)數(shù)據(jù)操作與控制(4)
Spire.Office for .NET是E-iceblue開(kāi)發(fā)的一種企業(yè)級(jí).NET Office編輯的軟件集合,包括Spire.Doc,Spire XLS,Spire.PDF,Spire.BarCode等等。.NET平臺(tái)的開(kāi)發(fā)人員可以使用Spire.Office for .NET輕松的操作含有文檔編輯功能的應(yīng)用程序,還可以導(dǎo)出為MS Word/Excel/RTF/Acces、PDF、XPS、HTML、XML等格式,使用Spire.Office,不需要安裝Microsoft Office。雖然Spire.Office for .NET是商業(yè)產(chǎn)品,但它的每一個(gè)基礎(chǔ)功能組件都提供了免費(fèi)版本。可以去官網(wǎng)看看:http://www.e-iceblue.com/。雖然有一些限制,但簡(jiǎn)單的東西還是可以試一試。本文介紹的Spire.XLS只是Spire.Office下面的一個(gè)操作Excel的組件。
前一篇文章:“.NET讀寫(xiě)Excel工具Spire.Xls使用(3)單元格控制 ”給大家介紹了Spire.XLS的中單元格的格式等控制功能,這篇文章將重點(diǎn)介紹C#操作Excel文件時(shí),對(duì)數(shù)據(jù)的控制。單元格和數(shù)據(jù)是Excel文件的核心,很難將兩者單獨(dú)分開(kāi)講解或者學(xué)習(xí),有時(shí)候都是交叉的。所以這篇文章的內(nèi)容有一部分在前一篇文章中其實(shí)已經(jīng)說(shuō)過(guò)了,例如單元格數(shù)據(jù)的編輯修改,這里就不再重復(fù)講解。
1.Excel行分組顯示
在數(shù)據(jù)很多的時(shí)候,有時(shí)候需要進(jìn)行分組顯示,可以隱藏很多細(xì)節(jié)。在需要的時(shí)候再點(diǎn)擊看詳細(xì)的內(nèi)容,相當(dāng)于明細(xì)表吧。當(dāng)然可能也不一定是這樣??傊褪荅xcel表的分組功能,就像下面這個(gè)樣子,注意看 行號(hào) 的變化,中間行號(hào)的行分組隱藏起來(lái)的:
下面看看如何使用Spire.XLS來(lái)在程序中設(shè)置分組操作,其實(shí)也非常簡(jiǎn)單,這就是商業(yè)組件的好處,把功能做到細(xì)致,1個(gè)函數(shù)就實(shí)現(xiàn)想要的功能,使用的是sheet對(duì)象的GroupByRows方法,如下面例子:
static void ExcelTest6() { Workbook workbook = new Workbook(); //獲取第一個(gè)sheet,進(jìn)行操作,下標(biāo)是從0開(kāi)始 Worksheet sheet = workbook.Worksheets[0]; sheet.GroupByRows(2, 9, true);//最后1個(gè)bool參數(shù)是默認(rèn)是否折疊 workbook.SaveToFile("Sample.xls", ExcelVersion.Version97to2003); System.Diagnostics.Process.Start("Sample.xls"); }
效果如下,把第2-9行分組,默認(rèn)是折疊的:
2.向單元格快速填充數(shù)組
在前一篇文章中,我們都是直接向單元格寫(xiě)入數(shù)據(jù),這個(gè)想起來(lái)也很繁瑣,所以我也會(huì)想能不能直接一次性將數(shù)組全部寫(xiě)入,這些豈不是更快更方便,代碼也更少。在查看Spire.XLS的官方案例的時(shí)候,還真發(fā)現(xiàn)了這么個(gè)功能,非常強(qiáng)大,對(duì)于導(dǎo)入數(shù)據(jù)非常管用:直接在指定位置插入二維數(shù)組,批量操作,省去了逐個(gè)單元格操作的煩惱??纯聪旅娲a:
static void ExcelTest7() { Workbook workbook = new Workbook(); workbook.CreateEmptySheets(1); Worksheet sheet = workbook.Worksheets[0]; int maxRow = 10; int maxCol = 5; //生成測(cè)試數(shù)據(jù)數(shù)組 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; } } //將數(shù)組插入到sheet中,后面參數(shù)是起始的行和列號(hào) sheet.InsertArray(myarray, 1, 1); workbook.SaveToFile("test.xls"); System.Diagnostics.Process.Start("test.xls"); }
效果如下圖所示,截圖不完整。。。反正就是這個(gè)意思,當(dāng)然你還可以寫(xiě)入其他格式的數(shù)據(jù):
3.查找與替換數(shù)據(jù)
在處理大量的數(shù)據(jù)的時(shí)候,Excel中sheet的查找與替換是很常見(jiàn)的,平時(shí)雖然手動(dòng)操作比較多,程序操作是怎么樣的呢?其實(shí)也很簡(jiǎn)單,對(duì)sheet對(duì)象進(jìn)行搜索,使用FindAllXXX方法找到相應(yīng)的單元格即可,注意XXX代表不同的數(shù)據(jù)類型,如FindAllBool,F(xiàn)indAllDateTime,F(xiàn)indAllNumber,F(xiàn)indAllString等等??匆粋€(gè)例子演示如何直接進(jìn)行查找和替換,并修改對(duì)應(yīng)單元格顏色的例子:
CellRange[] ranges = sheet.FindAllString("test", false, false); //循環(huán)找到的單元格 foreach (CellRange range in ranges) { range.Text = "修改后"; range.Style.Color = Color.Yellow; }
4.數(shù)據(jù)過(guò)濾器創(chuàng)建與取消
過(guò)濾器是啥玩意,可能一般人不會(huì)注意,當(dāng)然經(jīng)常使用Excel的人,過(guò)濾器是必不可少的。就是將列進(jìn)行篩選,自動(dòng)列出選項(xiàng),然后操作者根據(jù)需要選擇選項(xiàng),顯示指定條件的數(shù)據(jù),相當(dāng)于一個(gè)動(dòng)態(tài)查詢的過(guò)程吧。Excel的速度很快,很方便,就是下面這種效果:
實(shí)際的代碼也很簡(jiǎn)單,如下面的代碼,看方法的原型就知道啥意思了。選擇表和范圍,設(shè)置樣式就可以了。
Workbook workbook = new Workbook(); workbook.LoadFromFile("test.xlsx"); Worksheet sheet = workbook.Worksheets[0]; //創(chuàng)建過(guò)濾器 sheet.ListObjects.Create("Table", sheet.Range[1, 1, sheet.LastRow, sheet.LastColumn]); sheet.ListObjects[0].BuiltInTableStyle = TableBuiltInStyles.TableStyleLight9; workbook.SaveToFile("Filter.xlsx", ExcelVersion.Version2010);
當(dāng)然,有時(shí)候也需要取消過(guò)濾器,需要過(guò)濾器只需要一個(gè)下面一個(gè)清空操作即可:
sheet.AutoFilters.Clear();
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C#(.NET)數(shù)據(jù)訪問(wèn)連接、查詢、插入等操作的封裝類
一個(gè)C#(.NET)數(shù)據(jù)訪問(wèn)連接、查詢、插入等操作的封裝類2008-05-05Entity Framework Core中執(zhí)行SQL語(yǔ)句和存儲(chǔ)過(guò)程的方法介紹
這篇文章介紹了Entity Framework Core中執(zhí)行SQL語(yǔ)句和存儲(chǔ)過(guò)程的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-02-02[.net] 操縱自如-頁(yè)面內(nèi)的配合與通信
[.net] 操縱自如-頁(yè)面內(nèi)的配合與通信...2007-07-07asp.net core webapi項(xiàng)目配置全局路由的方法示例
這篇文章主要介紹了asp.net core webapi項(xiàng)目配置全局路由的方法示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-09-09.NET發(fā)送郵件的實(shí)現(xiàn)方法示例
這篇文章主要給大家介紹了關(guān)于.NET發(fā)送郵件的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用.net具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-06-06Asp.net 連接MySQL的實(shí)現(xiàn)代碼[]
ASP.NET連接MySQL需要一個(gè)組件(.net本身不提供訪問(wèn)MySQL的驅(qū)動(dòng))MySQL.Data.Dll,此為官方提供(純C#開(kāi)發(fā),開(kāi)源噢),有多個(gè)版本選擇,采用的數(shù)據(jù)訪問(wèn)模式為ADO.NET,跟asp.net訪問(wèn)sqlserver很像,非常簡(jiǎn)單。2009-08-08.net core如何利用ConcurrentTest組件對(duì)方法進(jìn)行壓力測(cè)試詳解
這篇文章主要給大家介紹了關(guān)于.net core如何利用ConcurrentTest組件對(duì)方法進(jìn)行壓力測(cè)試的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧2018-11-11解決asp.net mvc UpdateModel更新對(duì)象后出現(xiàn)null問(wèn)題的方法
這篇文章主要介紹了解決asp.net mvc UpdateModel 更新對(duì)象后出現(xiàn)null問(wèn)題的方法,需要的朋友可以參考下2015-11-11vb 中的MD5加密在asp.net中的實(shí)現(xiàn)
給定標(biāo)識(shí)哈希類型的密碼和字符串,該例程產(chǎn)生一個(gè)適合存儲(chǔ)在配置文件中的哈希密碼,感興趣的朋友可以參考下本文2013-04-04