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行开始)

达奇AI论文写作
达奇AI论文写作

达奇AI论文辅助写作平台,在校学生、职场精英都在用的AI论文辅助写作平台

下载
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中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

910

2023.08.02

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

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

596

2024.08.29

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

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

294

2025.08.29

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

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

210

2025.08.29

string转int
string转int

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

910

2023.08.02

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

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

596

2024.08.29

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

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

294

2025.08.29

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

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

210

2025.08.29

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

45

2026.02.28

热门下载

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

精品课程

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

共162课时 | 19.6万人学习

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