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文件中的数据:

一点PPT
一点PPT

一句话生成专业PPT,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 <= sheet.LastRowNum; i++)
   {
      IRow row = sheet.GetRow(i);
      if (row == null) continue;

      for (int j = row.FirstCellNum; j < row.LastCellNum; 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批量导入数据到数据库,或导出报表。掌握基本读写后,可进一步探索公式、图表、图片等高级功能。不复杂但容易忽略细节,比如单元格类型判断和流的管理。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

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

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

338

2023.10.31

php数据类型
php数据类型

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

225

2025.10.31

c语言 数据类型
c语言 数据类型

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

138

2026.02.12

string转int
string转int

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

1031

2023.08.02

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

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

367

2023.11.13

java boolean类型
java boolean类型

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

42

2025.11.30

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

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

254

2023.09.22

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

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

1089

2024.03.01

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

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

精品课程

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

共162课时 | 21.3万人学习

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

共28课时 | 2.6万人学习

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

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