C# 读取Excel表格出现空白行原因及解决办法

在C#中读取Excel时,可能会遇到因空白行导致的导入错误。问题在于Excel的已使用最大行数包括了空行,这在填充到DataTable时造成困扰。解决方法包括在SQL查询时过滤非空行,或在DataTable中删除空白行。建议根据业务需求在读取前或读取后处理空白行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

                  在应用系统中,Excel数据的导入、导出和打印功能需求肯定是再常见不过的功能了。然而我们在做Excel导入的工程中往往会为报错,这类错误可能在业务层面你有空值校验的提示,但是从Excel打开后的内容用人类的肉眼你是看不出来有空行的,或者Excel的内容不存在你系统所报错提醒信息的。那么原因到底出在哪儿呢?心细的程序员或仔细观察和监视读取Excel返回结果集下面有些许空白行,就是这些空白行在作怪,它们的存在导致很多业务校验不通过,或者没有校验时直接是Insert到数据库表失败,即使侥幸Insert成功,可是到最后空白的记录也是无用的还产生了垃圾数据。

                Excel读取存在空白的原因:表格有两个后台属性,分别是已使用的最大行数和已使用的最大列数。这个adapter可能是按这两个属性来的,没法改。读取代码部分如图所示,图示为主要解析Excel到DataTable.经过仔细监视代码我们会发现在da.Fill(dt)时,把空白行填充到DataTable了。总体来讲这个是有微软提供的方法和规则,那么是没办法改的。

 

整体部分如下:

 

 public static DataSet GetDataFromExcel(strin

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值