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/n/370745.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
FIQKYFIQKY
上一篇 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

发表回复

登录后才能评论