用C#读取EXCEL时提示 对象不能从 DBNull 转换为其他类型。
string strConnUpload="Provider=Microsoft.Jet.OLEDB.4.0; Data Source= "+ FullPath+ "; Extended Properties=Excel 8.0 ;";
OleDbConnection connUpload = new OleDbConnection(strConnUpload);
string strSQL = "SELECT * FROM [Sheet1$]";
OleDbDataAdapter daUpload = new OleDbDataAdapter(strSQL,connUpload);
DataSet dsUpload = new DataSet();
daUpload.Fill(dsUpload,"a");
connUpload.Close();
for (int iRow=0;iRow<dsUpload.Tables["a"].Rows.Count; iRow++)
{
int number=Convert.ToInt32(dsUpload.Tables["a"].Rows[iRow][0]);
string card=Convert.ToString(dsUpload.Tables["a"].Rows[iRow][2]);
double money=Convert.ToDouble(dsUpload.Tables["a"].Rows[iRow][3]);
sql="insert into pay VALUES("+number+",'"+card+"',"+money+","+bank_id+",'"+mon+"')";
cmd.CommandText=sql;
conn.Open();
cmd.ExecuteNonQuery();
conn.Close();
}
象不能从 DBNull 转换为其他类型。
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。
异常详细信息: System.InvalidCastException: 对象不能从 DBNull 转换为其他类型。
源错误: 行151错。
行 149:for (int iRow=0;iRow<dsUpload.Tables["a"].Rows.Count; iRow++)
行 150:{
行 151: int number=Convert.ToInt32(dsUpload.Tables["a"].Rows[iRow][0]);
行 152: string card=Convert.ToString(dsUpload.Tables["a"].Rows[iRow][2]);
行 153: double money=Convert.ToDouble(dsUpload.Tables["a"].Rows[iRow][3]);