1. 程式人生 > >【原創】.NET讀寫Excel工具Spire.Xls使用(3)單元格控制

【原創】.NET讀寫Excel工具Spire.Xls使用(3)單元格控制

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

  以前在使用NPOI的時候,其實印象最深的還是單元格的操作,因為以前使用NPOI的主要任務是生成一個複雜的統計報表,不僅表頭比較複雜,而且行類別的控制也比較複雜,不是固定的,要動態的進行。並且不同單元格的邊框還不一樣,所以當初使用 NPOI 也走了不少彎路。對單元格的控制是寫入Excel檔案的最核心的東西。所以本篇文章就介紹我在使用Spire.XLS過程中相關單元格的控制總結。

1.Excel單元格概述

  Excel單元格是表格的最小編輯單元,也是操作的主體,日常涉及到的相關功能有:

1.對指定單元格讀寫內容:讀寫內容的時候,有一些操作可以和格式控制,如單元格的型別進行合併;

2.對單元格的格式進行控制,如數字,字串,文字顏色,字型大小等等;對於自定義報表等檔案,這個要求是比較常見的;

3.對單元格的樣式進行控制,如邊框線條(樣式,顏色),內容對齊,合併單元格等等,也是很常見的;

4.單元格的相關統計,如一些函式,求和統計功能等等;

  接下來的內容主要對上述4個主要用途進行演示,附一些實際程式碼。如果有需要補充的,請留言。

2.單元格內容的讀寫

  在Spire.XLS中讀寫單元格,主要的一個物件不可不知,那就是CellRange,代表是單元格的一個範圍集合,可以根據單元格的名稱如A1,B2來返回單元格集合,也可以根據行號和列號(下標從1開始)來訪問。例如下面的程式碼,直接對A1單元格賦值,然後對第一行第2個單元格賦值。相比NPOI,不停的Create再賦值,這確實方便不少。看程式碼:

 1 static void ExcelTest5()
 2 {
 3     //建立1個工作簿,相當於1個Excel檔案
 4     Workbook workbook = new Workbook();
 5 
 6     //獲取第一個sheet,進行操作,下標是從0開始
7 Worksheet sheet = workbook.Worksheets[0]; 8 9 //向A1單元格寫入文字 10 sheet.Range["A1"].Text = "我是A1單元格"; 11 sheet.Range[1, 2].Text = "我是第1行的第2個單元格"; 12 13 //將Excel檔案儲存到指定檔案,還可以指定Excel版本 14 workbook.SaveToFile("例子.xls", ExcelVersion.Version97to2003); 15 }

看效果:

而如果要訪問對應單元格的值,也是可以直接通過上述CellRange獲取單元格物件後,直接訪問其屬性Value,或者TextNumberValue來獲取你想要型別的值,不需要自己轉換。但是前提你要知道單元格的格式。如下面程式碼:

1 Console.WriteLine(sheet.Range["A1"].Value);
2 Console.WriteLine(sheet.Range["B1"].Text);

3.單元格的內容格式與樣式

3.1 單元格的資料型別

  在使用NPOI的過程中,不僅單元格要頻繁Create,對寫入的資料格式也要設定,而在Spire.XLS中,這些變得更簡單了。直接根據資料型別給指定屬性就OK了,非常簡潔明瞭。例如,下面的程式碼,直接向單元格寫入雙精度,日期和布林型別的資料,給NumberValue,DateTimeValue,BooleanValue屬性直接賦值就好了。

1 //向A1單元格寫入文字
2 sheet.Range["A1"].Text = "我是A1單元格";
3 sheet.Range[1, 2].Text = "我是第1行的第2個單元格";
4 
5 sheet.Range["A3"].NumberValue = 100.23;
6 sheet.Range["A4"].DateTimeValue = DateTime.Now;            
7 sheet.Range["A5"].BooleanValue = true;

   是不是非常簡單,一行程式碼搞定的東西,以前可能要幾行,多了之後也有些頭疼。

3.2 單元格的字型格式

  以前的NPOI樣式的控制,要單獨新建樣式物件進行設定,而在Spire.XLS中,更加直接,直接對Range的屬性進行設定就好了,非常簡單明瞭,看看我們對範圍內的單元格是如何控制字型格式的,只列舉了幾個屬性,其他屬性以此類推:

1 //對一定範圍內的單元格進行字型控制
2 sheet.Range["A1:B10"].Style.Font.FontName = "微軟雅黑";//字型名稱
3 sheet.Range["A1:B10"].Style.Font.Size = 20;//字型大小
4 sheet.Range["A1:B10"].Style.Font.Underline = FontUnderlineType.DoubleAccounting;//下劃線型別

看看效果:

  是不是更簡單,Range的範圍選擇也很靈活。

3.3 合併單元格

  合併單元格在用Excel做報表的時候很有用,在C#中操作合併單元格,其實也非常容易。

1 //將A5-B6的單元格合併
2 sheet.Range["A5:B6"].Merge();
3 //將某一行全部合併
4 sheet.Rows[7].Merge();

這裡要注意:合併一行的話,不是把所有一行單元格都合併掉,而是預設合併到最後一列(取最大有值的列)。效果如下:

  有的時候需要取消合併單元格,其實和上面原理是一樣的,用的是UnMerge方法。這裡就不再演示。

3.4 單元格的其他功能

  其實單元格的操作還有很多,例如格式的複製應用到其他單元格,隱藏行或者列,插入行或者列等等,這些做起來其實都很簡單,可以參考官方網站提供的教程,由於我這方面用得少,就不詳細介紹了,以後自己用得上的話,也是去翻這些文件:官方教程連結

4.資原始碼

相關推薦

原創.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自己控制的

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

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

原創隨機產生漢字姓名(2、3、4字)

分享圖片 漢字 while info 圖片 技術 don create ray 如圖所示,想要產生隨機漢字姓名,該怎麽辦? 小二的源碼分享(轉載請註明出處): #!/bin/sh ########################################