0

0

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

煙雲

煙雲

发布时间:2026-01-13 11:48:09

|

1014人浏览过

|

来源于php中文网

原创

推荐使用npoi操作excel,它是apache poi的.net移植版,免费开源、无需office,支持.xls与.xlsx格式;通过xssfworkbook/hssfworkbook读取工作表,遍历irow与icell获取数据,注意判断celltype避免异常。

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

用C#操作Excel文件,推荐使用NPOI——它是Apache POI的.NET移植版,免费、开源、无需安装Office,支持.xls(Excel 97-2003)和.xlsx(Excel 2007+)格式,读写稳定,适合后台服务和批量处理。

安装NPOI NuGet包

在Visual Studio中右键项目 → “管理NuGet程序包” → 搜索并安装:
NPOI(主包,含xls/xlsx支持)
• 可选:NPOI.Extension(提供更简洁的辅助方法,如自动类型转换)

读取Excel文件(.xlsx为例)

核心是XSSFWorkbook(xlsx)或HSSFWorkbook(xls),通过工作表(ISheet)和行(IRow)、单元格(ICell)逐级访问:

  • FileStream打开文件,构造XSSFWorkbook
  • GetSheetAt(0)GetSheet("Sheet1")获取工作表
  • 遍历行(sheet.LastRowNum + 1为总行数),跳过空行
  • 对每个单元格调用cell.ToString()cell.StringCellValue/cell.NumericCellValue,注意先判断cell.CellType避免异常

示例:读取首列姓名(假设第0行为标题,数据从第1行开始)

寻光
寻光

阿里达摩院寻光视频创作平台,以视觉AIGC为核心功能,用PPT制作的方式创作视频

下载
var fs = new FileStream("data.xlsx", FileMode.Open);
var wb = new XSSFWorkbook(fs);
var sheet = wb.GetSheetAt(0);
for (int i = 1; i   var row = sheet.GetRow(i);
  if (row == null) continue;
  var cell = row.GetCell(0);
  if (cell != null && cell.CellType == CellType.String) {
    Console.WriteLine(cell.StringCellValue);
  }
}
fs.Close(); wb.Close();

写入Excel文件(生成新.xlsx)

创建空白工作簿→添加工作表→创建行与单元格→设置值和样式→保存到文件流:

  • new XSSFWorkbook()新建工作簿
  • workbook.CreateSheet("数据表")添加工作表
  • sheet.CreateRow(0)创建第0行,再用row.CreateCell(0)创建单元格
  • 对单元格调用SetCellValue("文本")SetCellValue(123.45)
  • 最后用FileStream写入磁盘(注意用FileMode.Create

小技巧:可预先创建CellStyle(如加粗、居中、日期格式)并复用,提升性能。

常见问题与注意点

中文乱码? NPOI默认UTF-8,只要源文件编码正常、控制台/IDE支持Unicode,一般不会乱码;若导出CSV需手动指定编码。
日期读出来是数字? Excel内部用浮点数存日期,需用cell.DateCellValue获取DateTime对象,或用cell.ToString()直接得格式化字符串。
大文件卡顿? 避免一次性加载全部数据;可考虑SAX模式(XSSFReader)流式读取,但仅支持xlsx且不支持写入。
公式计算? NPOI默认不自动重算公式,可用workbook.GetCreationHelper().CreateFormulaEvaluator().Evaluate(cell)手动求值。

基本上就这些。NPOI上手快,文档全,GitHub上有大量示例。只要避开空单元格和类型误判,读写Excel很稳。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
string转int
string转int

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

930

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

601

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

294

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

212

2025.08.29

string转int
string转int

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

930

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

601

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

294

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

212

2025.08.29

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

4

2026.03.04

热门下载

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

精品课程

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

共162课时 | 20万人学习

成为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号