0

0

C#怎么操作Excel文件 C#读写Excel数据方法

月夜之吻

月夜之吻

发布时间:2026-01-15 08:21:08

|

686人浏览过

|

来源于php中文网

原创

最推荐用NPOI或EPPlus操作Excel:NPOI免费跨平台、支持.xls/.xlsx,适合企业后台;EPPlus语法简洁、.NET 5+友好,小项目首选;避免使用Interop因依赖Office且部署不稳定。

c#怎么操作excel文件 c#读写excel数据方法

用C#操作Excel文件,最推荐的方式是使用 NPOI(免费、跨平台、无需安装Office)或 EPPlus(功能强、语法简洁,.NET 5+ 更友好)。不建议用 Microsoft.Office.Interop.Excel,因为它依赖本地Office安装、性能差、服务器部署易出错。

用 NPOI 读写 Excel(支持 .xls 和 .xlsx)

NPOI 是 Apache POI 的 .NET 移植版,完全免费,适合企业级后台处理。

  • 安装 NuGet 包:NPOI
  • 读取 Excel(.xlsx)示例:
using NPOI.SS.UserModel;
using NPOI.XSSF.UserModel;
using System.IO;

using var fs = new FileStream("data.xlsx", FileMode.Open);
IWorkbook workbook = new XSSFWorkbook(fs);
ISheet sheet = workbook.GetSheetAt(0);
for (int i = 0; i   IRow row = sheet.GetRow(i);
  if (row != null) {
    string cellValue = row.GetCell(0)?.ToString() ?? "";
    Console.WriteLine(cellValue);
  }
}
  • 写入 Excel 示例:
IWorkbook workbook = new XSSFWorkbook();
ISheet sheet = workbook.CreateSheet("数据表");
IRow row = sheet.CreateRow(0);
row.CreateCell(0).SetCellValue("姓名");
row.CreateCell(1).SetCellValue("年龄");

using var fs = new FileStream("output.xlsx", FileMode.Create);
workbook.Write(fs);

用 EPPlus 写 Excel(仅 .xlsx,.NET Core/.NET 5+ 首选)

EPPlus 功能丰富、API 直观,尤其适合生成报表、设置样式、公式和图表。注意:6.x 起需商业授权(免费版限 10 万单元格),7.x 开源免费(MIT 协议)。

Whimsical
Whimsical

Whimsical推出的AI思维导图工具

下载
  • 安装 NuGet 包:EPPlus(v7+)
  • 读取并修改 Excel:
using OfficeOpenXml;
ExcelPackage.LicenseContext = LicenseContext.NonCommercial; // 免费项目可用

using var package = new ExcelPackage(new FileInfo("input.xlsx"));
var worksheet = package.Workbook.Worksheets[0];
string value = worksheet.Cells[1, 1].Value?.ToString();
worksheet.Cells[1, 1].Value = "已更新";
package.Save();

简单场景:只读 CSV(比 Excel 更轻量)

如果只是存取结构化文本数据,CSV 是更高效的选择。用 System.IOMicrosoft.VisualBasic.FileIO.TextFieldParser(支持带逗号/换行的字段)即可,无需额外依赖。

  • 写 CSV(用 StreamWriter):
using var writer = new StreamWriter("data.csv");
writer.WriteLine("姓名,年龄,城市");
writer.WriteLine($"张三,28,\"北京朝阳区\"");

避坑提醒

  • 别在 IIS 或 Linux 服务中调用 Interop —— 会卡死或报错
  • NPOI 读日期单元格时,要用 cell.DateCellValue,别直接 ToString()
  • EPPlus v7 默认禁用公式计算,如需结果,设 worksheet.Calculate()
  • 大文件(>10MB)建议用流式读写(NPOI 的 SXSSFWorkbook 或 EPPlus 的 LoadFromCollection 分批)

基本上就这些。小项目用 EPPlus v7 最省心,老系统兼容 .xls 就选 NPOI,纯数据交换优先考虑 CSV。

相关专题

更多
string转int
string转int

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

315

2023.08.02

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

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

537

2024.08.29

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

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

52

2025.08.29

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

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

197

2025.08.29

apache是什么意思
apache是什么意思

Apache是Apache HTTP Server的简称,是一个开源的Web服务器软件。是目前全球使用最广泛的Web服务器软件之一,由Apache软件基金会开发和维护,Apache具有稳定、安全和高性能的特点,得益于其成熟的开发和广泛的应用实践,被广泛用于托管网站、搭建Web应用程序、构建Web服务和代理等场景。本专题为大家提供了Apache相关的各种文章、以及下载和课程,希望对各位有所帮助。

405

2023.08.23

apache启动失败
apache启动失败

Apache启动失败可能有多种原因。需要检查日志文件、检查配置文件等等。想了解更多apache启动的相关内容,可以阅读本专题下面的文章。

930

2024.01.16

vsd文件打开方法
vsd文件打开方法

vsd文件打开方法有使用Microsoft Visio软件、使用Microsoft Visio查看器、转换为其他格式等。想了解更多vsd文件相关内容,可以阅读本专题下面的文章。

479

2023.10.30

excel对比两列数据异同
excel对比两列数据异同

Excel作为数据的小型载体,在日常工作中经常会遇到需要核对两列数据的情况,本专题为大家提供excel对比两列数据异同相关的文章,大家可以免费体验。

1377

2023.07.25

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

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

36

2026.01.14

热门下载

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

精品课程

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

共162课时 | 11.8万人学习

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