.NET 利用NPOI读取Excel到实体对象中

本文介绍了如何使用NPOI库在.NET环境中以泛型方式读取Excel文件内容,并将其映射到实体对象中。作者强调了方法的灵活性和效率,讨论了反射的使用以及表头与实体字段映射的处理策略,并提供了相关代码示例。
摘要由CSDN通过智能技术生成

前情提要

        今天接到一个需求,需要解析用户上传的Excel文件,将其中数据导入到数据库中,作为一个优秀的CV战士,率先肯定要去度娘找找有没有现成的解析方案,可无奈大多数解决方案都是通过NPOI读取到DateTable中,这样写出的代码不可避免的夹带一大堆索引操作,这对于天蝎座的强迫症来说怎么能忍的了,当场决定自己写一个解析Excel的方法.

设计

        首先这个方法肯定不能只支持一个标准,那写出来多low啊,实用性趋近于零,那它第一个特点必须是支持泛型,既然要支持泛型,那思考的方向就要偏向于利用反射,但反射效率低这个问题是需要考虑的,这个等下再提

        其次考虑到表格表头与我们得实体定义可能有区别,毕竟我们实体通常来讲是使用英文命名,考虑到这点,那必然要有一个映射关系,这里我们可以考虑标记一个特性去配置映射关系,当然这只是个想法,用key-value对象来存储映射关系也未尝不可,效率上回比标记特性要高一点点

实现

        不多bb,直接上代码

/// <summary>
/// 读取Excel到实体{T}
/// </summary>
/// <typeparam name="T">实体,需为类class</typeparam>
/// <param name="filepath">读取文件所在路径</param>
/// <param name="map">实体与表格的映射关系,默认第一行为表头</param>
/// <returns></returns>
public static List<T> ReadExcel<T>(string filepath, Dictionary<str
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值