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

错误提示:

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,如图。但是依旧报错
    dataGridView导出Excel时报错:未将对象引用到对象实例

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

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

巨人的肩膀:

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

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