溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

.NET讀寫Excel工具Spire.Xls之對(duì)數(shù)據(jù)操作與控制的示例分析

發(fā)布時(shí)間:2021-08-09 10:26:24 來(lái)源:億速云 閱讀:122 作者:小新 欄目:開(kāi)發(fā)技術(shù)

這篇文章給大家分享的是有關(guān).NET讀寫Excel工具Spire.Xls之對(duì)數(shù)據(jù)操作與控制的示例分析的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。

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)的:

.NET讀寫Excel工具Spire.Xls之對(duì)數(shù)據(jù)操作與控制的示例分析

下面看看如何使用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)是折疊的:

.NET讀寫Excel工具Spire.Xls之對(duì)數(shù)據(jù)操作與控制的示例分析

2.向單元格快速填充數(shù)組

   在前一篇文章中,我們都是直接向單元格寫入數(shù)據(jù),這個(gè)想起來(lái)也很繁瑣,所以我也會(huì)想能不能直接一次性將數(shù)組全部寫入,這些豈不是更快更方便,代碼也更少。在查看Spire.XLS的官方案例的時(shí)候,還真發(fā)現(xiàn)了這么個(gè)功能,非常強(qiáng)大,對(duì)于導(dǎo)入數(shù)據(jù)非常管用:直接在指定位置插入二維數(shù)組,批量操作,省去了逐個(gè)單元格操作的煩惱。看看下面代碼:

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)然你還可以寫入其他格式的數(shù)據(jù):

.NET讀寫Excel工具Spire.Xls之對(duì)數(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的速度很快,很方便,就是下面這種效果:

.NET讀寫Excel工具Spire.Xls之對(duì)數(shù)據(jù)操作與控制的示例分析

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

感謝各位的閱讀!關(guān)于“.NET讀寫Excel工具Spire.Xls之對(duì)數(shù)據(jù)操作與控制的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI