asp.net老项目运维,出现的问题2

在使用Microsoft.ACE.OleDb或NPOI方式读取EXCEL进行导入的时候,如果遇到excel某列内容格式不统一(比如既有数字格式又有字符串格式),那么就会导致读取到的内容有空值的情况,这个是以上两种方式天生的机制弊端,我们不能从根部解决问题,但是可以从外围解决,我想到两种解决方案:

方案一(还没实践过)

 strConP = "provider=Microsoft.ACE.OleDb.12.0;Data Source=" + Server.MapPath("~/OrdersUpdate") + "/" + filename + ";Extended Properties='Excel 12.0;HDR=yes;IMEX=1';";

我们经常用的读取字符串中有个HDR=yes代表首行是字段名,IMEX=1代表excel列采用混合模式读取,但你会发现即使这么设置了也不管用,那是因为IMEX=1只是从excel前8行中判断是否采用混合模式,如果前8行都是数字,后面行又出现了字符串类型,那么字符串被读取后还是空值。

了解以上情况后,可以改造一下字符,把HDR=no,IMEX=1, 再借助通常情况下首行数据类型都是字符串的规律,读取excel时前8行无论是数字,还是字符串,就都会按混合模式读取数据了,别忘了后续处理数据时过滤掉首行即可,这样就变相达到了目的。

方案二(已经在项目中使用)

就是发现某列经常有空值情况的,就事先把excel中这列所有内容加一个空格的前缀,然后进行导入,导入代码中再去掉前导空格,再进行后续操作。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值