0

0

C#怎么操作Excel文件 C#使用NPOI库读写Excel表格的方法

小老鼠

小老鼠

发布时间:2025-11-18 16:53:03

|

1012人浏览过

|

来源于php中文网

原创

使用NPOI库可高效读写Excel文件,无需安装Office软件。1. 通过NuGet安装NPOI包,支持.NET多版本;2. 读取Excel时,根据.xlsx格式创建XSSFWorkbook,遍历工作表行与单元格,结合CellType解析不同数据类型;3. 写入Excel时,新建工作簿与工作表,设置单元格值并保存至文件流;4. 注意区分.xls和.xlsx对应的不同类,妥善管理文件流释放,处理合并单元格及样式设置。NPOI适用于服务器端批量导入导出场景,功能强大且稳定。

c#怎么操作excel文件 c#使用npoi库读写excel表格的方法

C#操作Excel文件常用的方式是使用NPOI库,它是一个开源的.NET库,可以读写Microsoft Office格式文件,包括Excel(.xls和.xlsx)。相比Office Interop,NPOI无需安装Excel软件,性能更好,适合在服务器端处理表格数据。

1. 安装NPOI库

在项目中使用NuGet包管理器安装NPOI:

Install-Package NPOI

支持 .NET Framework 和 .NET Core/.NET 5+ 项目。

2. 使用NPOI读取Excel文件

以下代码演示如何读取一个Excel文件中的数据:

Solvely
Solvely

AI学习伴侣,数学解体,作业助手,家教辅导

下载

示例:读取第一个工作表的所有单元格内容

using NPOI.SS.UserModel;
using NPOI.XSSF.UserModel;
using System.IO;

string filePath = "test.xlsx";
using (FileStream fs = new FileStream(filePath, FileMode.Open, FileAccess.Read))
{
   IWorkbook workbook = new XSSFWorkbook(fs); // .xlsx 文件
   ISheet sheet = workbook.GetSheetAt(0); // 获取第一个工作表

   for (int i = sheet.FirstRowNum; i    {
      IRow row = sheet.GetRow(i);
      if (row == null) continue;

      for (int j = row.FirstCellNum; j       {
         ICell cell = row.GetCell(j);
         if (cell != null)
            Console.Write(GetCellValue(cell) + "\t");
      }
      Console.WriteLine();
   }
}

// 辅助方法:获取单元格实际值
static string GetCellValue(ICell cell)
{
   return cell.CellType switch
   {
      CellType.String => cell.StringCellValue,
      CellType.Numeric => cell.NumericCellValue.ToString(),
      CellType.Boolean => cell.BooleanCellValue.ToString(),
      CellType.Formula => cell.CellFormula,
      _ => ""
   };
}

3. 使用NPOI写入Excel文件

创建一个新的Excel文件并写入数据:

using NPOI.XSSF.UserModel;
using NPOI.SS.UserModel;
using System.IO;

using (IWorkbook workbook = new XSSFWorkbook())
{
   ISheet sheet = workbook.CreateSheet("Sheet1");

   // 创建第一行
   IRow headerRow = sheet.CreateRow(0);
   headerRow.CreateCell(0).SetCellValue("姓名");
   headerRow.CreateCell(1).SetCellValue("年龄");
   headerRow.CreateCell(2).SetCellValue("城市");

   // 添加数据行
   IRow dataRow = sheet.CreateRow(1);
   dataRow.CreateCell(0).SetCellValue("张三");
   dataRow.CreateCell(1).SetCellValue(28);
   dataRow.CreateCell(2).SetCellValue("北京");

   // 保存到文件
   using (FileStream fs = new FileStream("output.xlsx", FileMode.Create, FileAccess.Write))
   {
      workbook.Write(fs);
   }
}
Console.WriteLine("Excel文件已生成。");

4. 注意事项与常见问题

区分.xls和.xlsx格式:
- .xlsx(Excel 2007+)使用 XSSFWorkbook
- .xls(旧版)使用 HSSFWorkbook

文件流必须正确释放:
使用 using 语句确保 FileStream 和 Workbook 被及时释放,避免文件被占用。

处理合并单元格:
可通过 sheet.NumMergedRegions 和 sheet.GetMergedRegion() 获取合并区域信息。

设置单元格样式(可选):
NPOI支持字体、颜色、对齐方式等样式设置,通过 ICellStyle 实现。

基本上就这些。NPOI功能强大,适合大多数Excel导入导出场景,比如从Excel批量导入数据到数据库,或导出报表。掌握基本读写后,可进一步探索公式、图表、图片等高级功能。不复杂但容易忽略细节,比如单元格类型判断和流的管理。

相关专题

更多
数据类型有哪几种
数据类型有哪几种

数据类型有整型、浮点型、字符型、字符串型、布尔型、数组、结构体和枚举等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

301

2023.10.31

php数据类型
php数据类型

本专题整合了php数据类型相关内容,阅读专题下面的文章了解更多详细内容。

222

2025.10.31

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

315

2023.08.02

java中boolean的用法
java中boolean的用法

在Java中,boolean是一种基本数据类型,它只有两个可能的值:true和false。boolean类型经常用于条件测试,比如进行比较或者检查某个条件是否满足。想了解更多java中boolean的相关内容,可以阅读本专题下面的文章。

348

2023.11.13

java boolean类型
java boolean类型

本专题整合了java中boolean类型相关教程,阅读专题下面的文章了解更多详细内容。

24

2025.11.30

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

231

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

435

2024.03.01

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

736

2023.08.22

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

2

2026.01.14

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Excel 教程
Excel 教程

共162课时 | 11.7万人学习

成为PHP架构师-自制PHP框架
成为PHP架构师-自制PHP框架

共28课时 | 2.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号