1. 程式人生 > >【原創】.NET讀寫Excel工具Spire.Xls使用(4)對資料操作與控制

【原創】.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是商業產品,但它的每一個基礎功能元件都提供了免費版本。可以去官網看看:

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();

相關推薦

原創.NETExcel工具Spire.Xls使用(3)單元格控制

  前一篇文章:“.NET讀寫Excel工具Spire.Xls使用(2)Excel檔案的控制”給大家介紹了C#使用Spire.XLS來控制Excel檔案的基本功能和相關實踐程式碼。這篇文章將重點介紹C#操作Excel檔案時,對Excel單元格的控制。   以前在使用NPOI的時候,其實印象最深的還是

原創.NETExcel工具Spire.Xls使用(1)入門介紹

  在.NET平臺,操作Excel檔案是一個非常常用的需求,目前比較常規的方法有以下幾種: 1.Office Com元件的方式:這個方式非常累人,微軟的東西總是這麼的複雜,使用起來可能非常不便,需要安裝Excel,對於伺服器,有時候還需要為配置IIS許可權。折騰人,看到很多人在群裡面使用這個東西,出現各種抓

原創.NETExcel工具Spire.Xls使用(2)Excel檔案的控制

  前一篇文章:“.NET操作Excel利器Spire.Xls使用(1)入門介紹 ”給大家介紹了Spire.XLS的基本功能和一些比較。這篇文章將重點介紹C#操作Excel檔案時,對Excel檔案本身的相關設定,全域性控制的內容。因為這也是C#讀寫Excel檔案時經常碰到的文章,也是我在使用過程中的一

原創.NETExcel工具Spire.Xls使用(4)資料操作控制

  Spire.Office for .NET是E-iceblue開發的一種企業級.NET Office編輯的軟體集合,包括Spire.Doc,Spire XLS,Spire.PDF,Spire.BarCode等等。.NET平臺的開發人員可以使用Spire.Office for .NET輕鬆的操作含有

原創.NETExcel工具Spire.Xls使用(5)重量級的Excel圖表功能

  前一篇文章:“.NET讀寫Excel工具Spire.Xls使用(4)對資料操作與控制”給大家介紹了Spire.XLS對資料的控制相關功能,這一篇給大家介紹Spire.XLS最大的亮點所在,C#控制Excel生成圖表。將介紹C#生成不同型別圖表的方法,並介紹Excel圖表的相關操作,如調整大小,儲存

原創自己動手一個服務網關

exception 負責 lis world 前置 create ble ddr load 引言 什麽是網關?為什麽需要使用網關? 如圖所示,在不使用網關的情況下,我們的服務是直接暴露給服務調用方。當調用方增多,勢必需要添加定制化訪問權限、校驗等邏輯。當添加API網關後,

原創自己手實現Boost序列化簡易版

設計思路   在與多個系統進行網路互動時,序列化是不可缺少的技術。編寫一個C++語言的序列化實現,是練習運用模板超程式設計的絕佳案例,理解C++模板是如何"面向編譯期程式設計"的(業內好像沒有這個說法)。序列化物件處理基礎資料型別和類型別,boost的序列化功能劃分得更細緻,基本支援了C++語言

原創整數入優化 C++

一、背景 這是某道題目的狀態: 我的程式碼: 大牛的程式碼: 我瞬間萌幣了! 我有這麼慢?Are you kidding me? 點進去一看: void Read(int & p)

OpenCV3視訊cv::VideoCapture和cv::VideoWriter

OpenCV3和OpenCV2類似,視訊的讀、寫操作,分別通過cv::VideoCapture和cv::VideoWriter兩個類來實現。 1、視訊的讀取操作cv::VideoCapture cv::VideoCapture既支援視訊檔案的讀取,也支

Linux磁碟 測試

一、如何檢視當前磁碟的IO使用情況 使用命令:iotop Total DISK READ: 3.89 K/s | Total DISK WRITE: 0.00 B/s TID PRIO USER DISK READ DISK WRITE SWAPIN IO>

OSSBucket許可權

使用者建立的Bucket總共有三種許可權: /*私有 * 只允許自己讀寫操作,其他使用者沒有許可權 */ CannedAccessControlList acl_private = CannedAccessControlList.Private; /*公共讀寫

QtQSettings登錄檔、配置檔案

簡述 一般情況下,我們在開發軟體過程中,都會快取一些資訊到本地,可以使用輕量級資料庫sqlite,也可以操作登錄檔、讀寫配置檔案。 關於QSettings的使用前面已經介紹過了,比較詳細,見“更多參考”,下面介紹下QSettings常用功能-讀寫登錄檔、配置檔案。 簡述 優點 讀

原創.NET平臺機器學習元件-Infer.NET連載(一)介紹

關於本文件的說明   本文件基於Infer.NET 2.6對Infer.NET User Guide進行中文翻譯,但進行了若干簡化和提煉,按照原網站的思路進行,但不侷限與其順序。   歡迎傳播分享,必須保持原作者的資訊,但禁止將該文件直接用於商業盈利。   本人正在研究基於Infer.NET元件,並

原創.NET平臺機器學習元件-Infer.NET連載(二)貝葉斯分類器

關於本文件的說明   本文件基於Infer.NET 2.6對Infer.NET User Guide進行中文翻譯,但進行了若干簡化和提煉,按照原網站的思路進行,但不侷限與其順序。   歡迎傳播分享,必須保持原作者的資訊,但禁止將該文件直接用於商業盈利。   本人正在研究基於Infer.NET元件,並

MFCVCini檔案

可以用於載入時,讀取上一次的紀錄。 一:寫ini配置檔案: //獲取exe路徑 CString strPath; GetModuleFileName(NULL,strPath.GetBufferSetLength(MAX_PATH+1),M

delphitxt檔案

1. memo控制元件讀取txt memo1.Lines.LoadFromFile('E:/*/*.txt'); 2. Procedure NewTxt(FileName:String); Var F : Textfile; Begin if fileExists(Fil

原創.NET中Trace類和Debug類的應用舉例

  .NET中Trace類和Debug類的應用舉例 .NET中的Trace類和Debug類是System.Diagnostics名稱空間下的兩個用於除錯的類,在軟體開發中使用得當,可以幫助我們除錯開發程式,提高效率,很有用。其中,Debug類僅在除錯版本中有效,而Trace

轉載ReentrantReadWriteLock鎖的使用

Lock比傳統執行緒模型中的synchronized方式更加面向物件,與生活中的鎖類似,鎖本身也應該是一個物件。兩個執行緒執行的程式碼片段要實現同步互斥的效果,它們必須用同一個Lock物件。   讀寫鎖:分為讀鎖和寫鎖,多個讀鎖不互斥,讀鎖與寫鎖互斥,這是由jvm自己控制的

原創使用workstation安裝Xenserver 6.5+cloudstack 4.10----本地存儲模式

登錄 queue alt ast rim 4.0 個人學習 white 配置 1. 背景: 近期由於項目和個人學習得需求,開始接觸到Cloudstack,雖然雲計算概念在大學剛畢業的時候就已經略有耳聞,但是由於工作原因,也一直沒有了解,下班後想自己折騰下cloudstac

NPOIExcelSpire.XLS for.NET元件轉換Excel為PDF

首先要引用NPOI動態庫和Microsoft.Office.Interop.excel.dll (Microsoft.Office.Interop.excel.dll  最好使用使用NuGet下載 ,或者使用網上下載,網上下載以後解壓檔案,把Microsoft.Offic