0

0

C#怎么将Excel数据导入到List_C#如何快速映射表格数据【示例】

尼克

尼克

发布时间:2026-03-14 15:10:52

|

263人浏览过

|

来源于php中文网

原创

ExcelDataReader读Excel到List<T>最省事:用Stream+Json或手动映射,避坑需注意CanSeek、DBNull、列名映射、脏数据过滤及浮点/日期精度问题。

c#怎么将excel数据导入到list_c#如何快速映射表格数据【示例】

ExcelDataReader 读取 Excel 文件到 List<T> 最省事

直接用 ExcelDataReader + System.Text.Json 或手动映射,比 EPPlus 轻、比 OleDb 稳,尤其适合只读场景。它不依赖 Office 安装,也不触发 COM,纯 .NET Standard 兼容。

常见错误现象:NotSupportedException: Stream does not support seeking —— 传了未开启 CanSeek 的流(比如从 HttpRequest.Body 直接读);InvalidDataException: Unable to read beyond the end of the stream —— 文件被其他进程占用或损坏。

  • 务必用 using var stream = File.OpenRead("xxx.xlsx"); 或确保传入的 Stream 支持 Seek
  • 打开时加 new ExcelReaderConfiguration { ReadHeader = true },否则第一行会被当数据
  • 如果 Excel 列名含空格或特殊字符,映射到 C# 属性时得用 [JsonPropertyName("Order Date")] 或手动赋值,别硬靠属性名自动匹配

DataTable 中转再转 List<T> 是最稳的兼容写法

不是所有 Excel 都规整:合并单元格、空行、类型混杂(一列里有数字和文本)、日期格式不统一……这时候强求“一键映射”反而掉坑里。先读进 DataTable,再逐行校验转换,可控性高得多。

使用场景:导入模板由业务方提供,字段顺序/名称/格式经常变;需要跳过前几行说明;某列要按规则清洗(如把 “Y/N” 转成 bool)。

  • ExcelDataReader.AsDataSet() 得到 DataSet,取 Tables[0] 即可
  • 遍历 Rows 时,用 row["列名"] as string + int.TryParse() 比直接 (int)row["列名"] 安全十倍
  • 注意 Excel 里空单元格读出来是 DBNull.Value,不是 null,判空得写 == DBNull.Value

Mapper.Map<List<T>>(dataTable) 类型太松容易崩

很多示例用 AutoMapper 或 DataTableExtensions.ToList<T>() 一类扩展方法,看着一行代码搞定,实际运行时静默丢数据或抛 InvalidCastException —— 因为这些工具默认按列名+类型严格匹配,而 Excel 的“数字”列可能第 5 行突然塞了个 “N/A”,整个映射就中断。

闪念贝壳
闪念贝壳

闪念贝壳是一款AI 驱动的智能语音笔记,随时随地用语音记录你的每一个想法。

下载

性能影响:自动映射会反射每个属性,对 10 万行以上数据,比手写循环慢 3–5 倍;兼容性上,.NET 6+ 的 SourceGen 映射器虽快,但不支持运行时列名动态变更。

  • 真要用自动映射,先调用 dataTable.Rows.Cast<DataRow>().Where(r => r.ItemArray.All(c => c != DBNull.Value)) 过滤脏行
  • 给目标类属性加 [Column("实际列名")] 特性,别依赖大小写或下划线自动转换
  • 日期列务必显式指定 DateTime.ParseExact(..., "yyyy-MM-dd", ...),Excel 的日期序列号在不同区域设置下解析结果可能差一天

导出 Excel 再导入?小心浮点数精度和日期偏移

如果数据源本身是 Excel 导出的(比如用户改完又传回来),要注意 Excel 存储数字用双精度浮点,12345678901234567 这种长整数会变 12345678901234568;日期则可能比原始值多 1 天(Excel 1900 闰年 bug)。

这不是你代码的问题,是 Excel 格式限制。所以别拿导入后的 double 去 == 比较原始值,也别假设 DateTime 和 Excel 单元格显示完全一致。

  • 整数列优先读为 stringlong.TryParse(),绕过浮点截断
  • 日期列用 row.GetDateTime(索引)Convert.ToDateTime(row[索引]) 更准,前者走 Excel 内部序列号逻辑
  • 如果业务允许,导入后立刻存为 JSON 或数据库,别再导回 Excel——链路越长,精度损失越不可控

真正麻烦的从来不是怎么读进来,而是 Excel 里那些没写进需求文档的“人肉格式”:合并标题行、注释列、条件色块、隐藏列……这些没法靠库自动识别,得提前跟业务方约好模板规范,或者留个 ValidateBeforeImport() 手动检查逻辑。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

457

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

549

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

337

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

string转int
string转int

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

1051

2023.08.02

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的相关内容,可以阅读本专题下面的文章。

1110

2024.03.01

string转int
string转int

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

1051

2023.08.02

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

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

49

2026.03.13

热门下载

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

精品课程

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

共94课时 | 11.3万人学习

C 教程
C 教程

共75课时 | 5.4万人学习

C++教程
C++教程

共115课时 | 21.8万人学习

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

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