C# NPOI操作Excel

一、NPOI簡介

NPOI是一個在C#/.NET平台上使用的讀寫Excel2007及Excel 97-2003文件的開源組件。支持流和文件兩種方式讀取和寫入。NPOI是一款基於.NET框架的組件,可以更方便地處理Excel文件。同時,NPOI還支持Word和PowerPoint文件的處理。

NPOI具有NPOI.HSSF、NPOI.XSSF、NPOI.HPSF和NPOI.POIFSFilesystem四個包。其中,NPOI.HSSF適用於操作Excel2003及Excel 97-2003文件,而NPOI.XSSF適用於操作Excel2007文件。NPOI.HPSF可以讀取和寫入Office Document Properties,而NPOI.POIFSFilesystem可用於操作OLE2 Compound Document文件格式。

NPOI是NHibernate的一部分,可以與NHibernate無縫集成。

二、NPOI的特點

NPOI是使用C#語言開發的,可以運行在Windows、Linux和Mac系統上。NPOI支持各種類型的數據源,包括特定存儲庫、XML文檔和ADO數據源。NPOI的介面友好,易於使用。同時,NPOI還具有以下特點:

1、高效快速:NPOI使用基於流的方法,讀寫速度快,佔用內存少。

2、靈活可擴展:NPOI的API清晰簡單,易於擴展。可以通過繼承和重載方式新增自定義功能。

3、功能豐富:NPOI能夠實現Excel的大部分功能,包括單元格樣式、合併單元格、保護工作表和單元格、數據校驗等。

三、NPOI的安裝

在C#項目中使用NPOI需要引入NPOI的dll文件。NPOI官方網站提供了兩種獲取方式:

1、從NPOI的官網上下載源代碼後自行編譯得到dll文件。

//引入命名空間
using NPOI.XSSF.UserModel;
using NPOI.SS.UserModel;
using System.IO;
//創建Excel文件
XSSFWorkbook wb = new XSSFWorkbook();
ISheet sheet = wb.CreateSheet("Sheet1");
IRow row = sheet.CreateRow(0);
row.CreateCell(0).SetCellValue("This is a test");
row.CreateCell(1).SetCellValue(4.5);
row.CreateCell(2).SetCellValue(true);
//將Excel文件保存到磁碟文件中
FileStream sw = File.Create("D:\\workbook.xlsx");
wb.Write(sw);
sw.Close();

2、使用NuGet包管理器來獲取NPOI。

//安裝NPOI
Install-Package NPOI -Version 2.4.1
//引入命名空間
using NPOI.XSSF.UserModel;
using NPOI.SS.UserModel;
using System.IO;
//創建Excel文件
XSSFWorkbook wb = new XSSFWorkbook();
ISheet sheet = wb.CreateSheet("Sheet1");
IRow row = sheet.CreateRow(0);
row.CreateCell(0).SetCellValue("This is a test");
row.CreateCell(1).SetCellValue(4.5);
row.CreateCell(2).SetCellValue(true);
//將Excel文件保存到磁碟文件中
FileStream sw = File.Create("D:\\workbook.xlsx");
wb.Write(sw);
sw.Close();

四、NPOI操作Excel

以下是一段基本的使用NPOI操作Excel的代碼示例:

//引入命名空間
using NPOI.XSSF.UserModel;
using NPOI.SS.UserModel;
using System.IO;
//讀取Excel文件
FileStream fs = new FileStream("D:\\workbook.xlsx", FileMode.Open, FileAccess.Read);
XSSFWorkbook wb = new XSSFWorkbook(fs);
ISheet sheet = wb.GetSheet("Sheet1");//獲取Sheet1工作表
IRow row = sheet.GetRow(0);//獲取第一行
string cellValue = row.GetCell(0).ToString();//獲取第一行第一列單元格的值
//向Excel文件中寫入數據
row.CreateCell(1).SetCellValue("Hello world");//在第一行第二列寫入數據
FileStream sw = File.Open("D:\\workbook.xlsx", FileMode.Open, FileAccess.Write);
wb.Write(sw);//將Excel文件保存到磁碟文件中
sw.Close();

通過以上代碼,我們可以實現Excel文件的讀取和寫入,並且可以操作Excel文件中的單元格、行和列。

五、NPOI操作Excel中的常用功能

1、設置單元格樣式

NPOI支持多種樣式的單元格,包括字體、顏色、邊框、對齊方式等。以下是設置單元格樣式的代碼示例:

//引入命名空間
using NPOI.XSSF.UserModel;
using NPOI.SS.UserModel;
using System.IO;
//創建Excel文件
XSSFWorkbook wb = new XSSFWorkbook();
ISheet sheet = wb.CreateSheet("Sheet1");
IRow row = sheet.CreateRow(0);
ICellStyle style = wb.CreateCellStyle();//新建單元格樣式
style.Alignment = HorizontalAlignment.Center;//設置水平居中
style.VerticalAlignment = VerticalAlignment.Center;//設置垂直居中
sheet.SetColumnWidth(0, 20 * 256);//設置第一列列寬
IRow row = sheet.CreateRow(0);
ICell cell = row.CreateCell(0);
cell.SetCellValue("This is a test");
cell.CellStyle = style;//設置單元格樣式
//將Excel文件保存到磁碟文件中
FileStream sw = File.Create("D:\\workbook.xlsx");
wb.Write(sw);
sw.Close();

2、合併單元格

NPOI可以將單元格進行合併,合併後的單元格將佔用合併區域內的所有單元格。以下是合併單元格的代碼示例:

//引入命名空間
using NPOI.XSSF.UserModel;
using NPOI.SS.UserModel;
using System.IO;
//創建Excel文件
XSSFWorkbook wb = new XSSFWorkbook();
ISheet sheet = wb.CreateSheet("Sheet1");
IRow row = sheet.CreateRow(0);
ICellStyle style = wb.CreateCellStyle();//新建單元格樣式
style.Alignment = HorizontalAlignment.Center;//設置水平居中
style.VerticalAlignment = VerticalAlignment.Center;//設置垂直居中
sheet.SetColumnWidth(0, 20 * 256);//設置第一列列寬
IRow row = sheet.CreateRow(0);
ICell cell = row.CreateCell(0);
cell.SetCellValue("合併單元格");
cell.CellStyle = style;//設置單元格樣式
//合併單元格
sheet.AddMergedRegion(new CellRangeAddress(0, 4, 0, 4));//合併第一行到第五行,第一列到第五列的單元格
//將Excel文件保存到磁碟文件中
FileStream sw = File.Create("D:\\workbook.xlsx");
wb.Write(sw);
sw.Close();

3、保護工作表和單元格

NPOI可以保護工作表和單元格,以防止用戶意外地修改數據。以下是保護工作表和單元格的代碼示例:

//引入命名空間
using NPOI.XSSF.UserModel;
using NPOI.SS.UserModel;
using System.IO;
//創建Excel文件
XSSFWorkbook wb = new XSSFWorkbook();
ISheet sheet = wb.CreateSheet("Sheet1");
sheet.ProtectSheet("password");//保護工作表,設置密碼為password
IRow row = sheet.CreateRow(0);
row.CreateCell(0).SetCellValue("This is a test");
//保護單元格
ICellStyle style = wb.CreateCellStyle();
style.IsLocked = true;
sheet.DefaultColumnStyle = style;//設置默認單元格樣式
sheet.DefaultRowHeight = 500;//設置默認行高
sheet.LockFormatColumns = true;//鎖定所有列
sheet.LockFormatRows = true;//鎖定所有行
//將Excel文件保存到磁碟文件中
FileStream sw = File.Create("D:\\workbook.xlsx");
wb.Write(sw);
sw.Close();

4、數據校驗

NPOI可以對單元格進行數據校驗,以保證數據的正確性和完整性。以下是設置數據校驗的代碼示例:

//引入命名空間
using NPOI.XSSF.UserModel;
using NPOI.SS.UserModel;
using System.IO;
//創建Excel文件
XSSFWorkbook wb = new XSSFWorkbook();
ISheet sheet = wb.CreateSheet("Sheet1");
IRow row = sheet.CreateRow(0);
row.CreateCell(0).SetCellValue("Age:");
sheet.SetColumnWidth(0, 20 * 256);//設置第一列列寬
//數據校驗
IDataValidationHelper validationHelper = sheet.GetDataValidationHelper();
IDataValidationConstraint constraint = validationHelper.CreateNumericConstraint(ComparisonOperator.GreaterThan, "0");//設置數據校驗規則,數字必須大於0
CellRangeAddressList regions = new CellRangeAddressList(0, 0, 1, 1);//設置校驗單元格範圍
IDataValidation dataValidation = validationHelper.CreateValidation(constraint, regions);//創建數據校驗對象
sheet.AddValidationData(dataValidation);//將校驗對象應用到工作表
//將Excel文件保存到磁碟文件中
FileStream sw = File.Create("D:\\workbook.xlsx");
wb.Write(sw);
sw.Close();

六、總結

使用NPOI可以快速、方便地實現對Excel文件的讀寫操作。同時,NPOI還支持各種高級功能,如單元格樣式、合併單元格、保護工作表和單元格、數據校驗等。需要注意的是,在使用NPOI時需要引入相應的dll文件,並且API清晰簡單、易於擴展,可以滿足各種定製化需求。

原創文章,作者:FIQKY,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/370745.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
FIQKY的頭像FIQKY
上一篇 2025-04-22 01:14
下一篇 2025-04-22 01:14

相關推薦

  • Python棧操作用法介紹

    如果你是一位Python開發工程師,那麼你必須掌握Python中的棧操作。在Python中,棧是一個容器,提供後進先出(LIFO)的原則。這篇文章將通過多個方面詳細地闡述Pytho…

    編程 2025-04-29
  • Python操作數組

    本文將從多個方面詳細介紹如何使用Python操作5個數組成的列表。 一、數組的定義 數組是一種用於存儲相同類型數據的數據結構。Python中的數組是通過列表來實現的,列表中可以存放…

    編程 2025-04-29
  • Python操作MySQL

    本文將從以下幾個方面對Python操作MySQL進行詳細闡述: 一、連接MySQL資料庫 在使用Python操作MySQL之前,我們需要先連接MySQL資料庫。在Python中,我…

    編程 2025-04-29
  • Python磁碟操作全方位解析

    本篇文章將從多個方面對Python磁碟操作進行詳細闡述,包括文件讀寫、文件夾創建、刪除、文件搜索與遍歷、文件重命名、移動、複製、文件許可權修改等常用操作。 一、文件讀寫操作 文件讀寫…

    編程 2025-04-29
  • Python代碼實現迴文數最少操作次數

    本文將介紹如何使用Python解決一道經典的迴文數問題:給定一個數n,按照一定規則對它進行若干次操作,使得n成為迴文數,求最少的操作次數。 一、問題分析 首先,我們需要了解迴文數的…

    編程 2025-04-29
  • 為什麼不能用Microsoft Excel進行Python編程?

    Microsoft Excel是一個廣泛使用的數據分析工具,但是它不能直接用於Python編程。這是因為Microsoft Excel並不是一個編程工具,它的主要功能是進行數據處理…

    編程 2025-04-29
  • Python元祖操作用法介紹

    本文將從多個方面對Python元祖的操作進行詳細闡述。包括:元祖定義及初始化、元祖遍歷、元祖切片、元祖合併及比較、元祖解包等內容。 一、元祖定義及初始化 元祖在Python中屬於序…

    編程 2025-04-29
  • 如何用Python對數據進行離散化操作

    數據離散化是指將連續的數據轉化為離散的數據,一般是用於數據挖掘和數據分析中,可以幫助我們更好的理解數據,從而更好地進行決策和分析。Python作為一種高效的編程語言,在數據處理和分…

    編程 2025-04-29
  • Python列表的讀寫操作

    本文將針對Python列表的讀取與寫入操作進行詳細的闡述,包括列表的基本操作、列表的增刪改查、列表切片、列表排序、列表反轉、列表拼接、列表複製等操作。 一、列表的基本操作 列表是P…

    編程 2025-04-29
  • Python序列的常用操作

    Python序列是程序中的重要工具,在數據分析、機器學習、圖像處理等很多領域都有廣泛的應用。Python序列分為三種:列表(list)、元組(tuple)和字元串(string)。…

    編程 2025-04-28

發表回復

登錄後才能評論