在应用系统中,Excel数据的导入、导出和打印功能需求肯定是再常见不过的功能了。然而我们在做Excel导入的工程中往往会为报错,这类错误可能在业务层面你有空值校验的提示,但是从Excel打开后的内容用人类的肉眼你是看不出来有空行的,或者Excel的内容不存在你系统所报错提醒信息的。那么原因到底出在哪儿呢?心细的程序员或仔细观察和监视读取Excel返回结果集下面有些许空白行,就是这些空白行在作怪,它们的存在导致很多业务校验不通过,或者没有校验时直接是Insert到数据库表失败,即使侥幸Insert成功,可是到最后空白的记录也是无用的还产生了垃圾数据。
Excel读取存在空白的原因:表格有两个后台属性,分别是已使用的最大行数和已使用的最大列数。这个adapter可能是按这两个属性来的,没法改。读取代码部分如图所示,图示为主要解析Excel到DataTable.经过仔细监视代码我们会发现在da.Fill(dt)时,把空白行填充到DataTable了。总体来讲这个是有微软提供的方法和规则,那么是没办法改的。
整体部分如下:
public static DataSet GetDataFromExcel(strin