错误提示:
查询一些机房重构的博客,导致这个问题出现可能是一下几种原因:
- 所设置的变量为空值或没有取到值,一般在传递参数的时候出现这个问题,也会在使用DateGird或gridview或datalist等数据空间时出现。
- 控件名称与codebehind里面的没有对应
- 未用new初始化对象
- 在程序中所引用的控件不存在
还查找其他一些地方:未将对象引用到对象实例,出现这种问题,一般是些什么原因,总结如下:
- ViewState 对象为Null。
- DateSet 空
- sql语句或Datebase的原因导致DataReader空。
- 声明字符串变量时未赋空值就应用变量。
- 未用new初始化对象。
- Session对象为空。
- 对控件赋文本值时,值不存在。
- 使用Request.QueryString()时,所获取的对象不存在,或在值为空时未赋初始值。
- 使用FindControl时,控件不存在却没有做预处理。
- 重复定义造成未将对象引用设置到对象的实例错误.
对于这些导致问题出现的原因,我有很多的地方不懂,但是将我懂得地方都排查了一下:
- 首先我将dataGridView控件绑定列属性都对应了一遍,果然发现了我比数据库多写了一个列,但是更改后依旧报错。
- 如果DataGridview最后有一空行,也会出现这个错误,于是我改了DataGridview的AllowUserToAddRows为False,如图。但是依旧报错
- 于是我断点调试,发现数据都传过来了,只是在导出Excel的时候出错。经过一番查询,找到解决方案
将这句:excel.Cells[i + 2, j + 1] = dataGridView1[j, i].Value.ToString();
更改为:excel.Cells[i + 2, j + 1] = dataGridView1[j, i].Value;
巨人的肩膀:
我能说被这个错误折磨好几天了吗!额~都有点丧了!就在前几分钟突然查到了解决方案,好开心。我要是早点积极的解决就好了,以后遇到问题不能任由自己丧下去了,只有去解决,总会找到办法,虽然最后还是站在巨人的肩膀上解决的。下面是巨人的肩膀,正好是两个肩膀,嘻嘻。。。
【重构】导出Excel时出错:未将对象引用到对象的实例未将对象引用设置到对象的实例–可能出现的问题总结