前情提要
今天接到一个需求,需要解析用户上传的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