dataGridView导出Excel时报错:未将对象引用到对象实例

错误提示:

在这里插入图片描述


查询一些机房重构的博客,导致这个问题出现可能是一下几种原因:
  1. 所设置的变量为空值或没有取到值,一般在传递参数的时候出现这个问题,也会在使用DateGird或gridview或datalist等数据空间时出现。
  2. 控件名称与codebehind里面的没有对应
  3. 未用new初始化对象
  4. 在程序中所引用的控件不存在

还查找其他一些地方:未将对象引用到对象实例,出现这种问题,一般是些什么原因,总结如下:
  • ViewState 对象为Null。
  • DateSet 空
  • sql语句或Datebase的原因导致DataReader空。
  • 声明字符串变量时未赋空值就应用变量。
  • 未用new初始化对象。
  • Session对象为空。
  • 对控件赋文本值时,值不存在。
  • 使用Request.QueryString()时,所获取的对象不存在,或在值为空时未赋初始值。
  • 使用FindControl时,控件不存在却没有做预处理。
  • 重复定义造成未将对象引用设置到对象的实例错误.

对于这些导致问题出现的原因,我有很多的地方不懂,但是将我懂得地方都排查了一下:
  1. 首先我将dataGridView控件绑定列属性都对应了一遍,果然发现了我比数据库多写了一个列,但是更改后依旧报错。

  2. 如果DataGridview最后有一空行,也会出现这个错误,于是我改了DataGridview的AllowUserToAddRows为False,如图。但是依旧报错
    在这里插入图片描述

  3. 于是我断点调试,发现数据都传过来了,只是在导出Excel的时候出错。经过一番查询,找到解决方案

将这句:excel.Cells[i + 2, j + 1] = dataGridView1[j, i].Value.ToString(); 
更改为:excel.Cells[i + 2, j + 1] = dataGridView1[j, i].Value;  

巨人的肩膀:

我能说被这个错误折磨好几天了吗!额~都有点丧了!就在前几分钟突然查到了解决方案,好开心。我要是早点积极的解决就好了,以后遇到问题不能任由自己丧下去了,只有去解决,总会找到办法,虽然最后还是站在巨人的肩膀上解决的。下面是巨人的肩膀,正好是两个肩膀,嘻嘻。。。

【重构】导出Excel时出错:未将对象引用到对象的实例
未将对象引用设置到对象的实例–可能出现的问题总结


  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 10
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值