asp.net Web应用程序中的ArgumentNull异常

时间:2013-02-19 08:15:05

标签: asp.net exception file-upload argumentnullexception

我开发了一个asp.net应用程序,其中输入将通过excel表格给出。 此应用程序在WINDOWS XP和MS Office 2008系统中运行良好。 如果我尝试在WINDOWS 7和MS Office 2010的系统中运行相同的应用程序,我会得到一个参数空例外。

代码:

foreach (var dr in data)
            {
                LHSupdate = new LHSUpdate();
                if (!string.IsNullOrEmpty(Convert.ToString(dr["Associate Id"])))
                {
                    AssociateID = Convert.ToString(dr["Associate Id"]);
                }
                LHSupdate.AssciateID = AssociateID;
                if (!string.IsNullOrEmpty(Convert.ToString(dr["Associate Name"])))
                {
                    AssociateName = Convert.ToString(dr["Associate Name"]);
                }
                LHSupdate.Name = AssociateName;

                var designation = dsData.Tables["LHS"].AsEnumerable().Where(r => Convert.ToString(r["Associate Id"]).Trim() == LHSupdate.AssciateID.Trim());

                if (designation != null)
                {
                    foreach (var de in designation)
                    {
                        LHSupdate.Designation = Convert.ToString(de["Level"]);
                    }
                }

                else
                {
                    LHSupdate.Designation = "";
                }                
                LHSupdate.CourseName = Convert.ToString(dr["Trainings "]);
                LHSupdate.CourseStatus = Convert.ToString(dr["Training Status"]);
                LHSupdate.Score = Convert.ToString(dr["Credits"]);
                LHSupdate.LearningMode = Convert.ToString(dr["Venue"]);
                LHSupdate.StartDate = Convert.ToString(dr["Start Date"]);
                LHSupdate.EndDate = Convert.ToString(dr["End Date"]);                
                lstLHS.Add(LHSupdate);
            }

我收到错误:

var designation = dsData.Tables["LHS"].AsEnumerable().Where(r => Convert.ToString(r["Associate Id"]).Trim() == LHSupdate.AssciateID.Trim());

代码:

private DataSet Getdata()
        {
            string connectionString = "";
            string getExcelSheetName = string.Empty;
            if (fuLHSEntry.HasFile)
            {
                string fileName = Path.GetFileName(fuLHSEntry.PostedFile.FileName);
                string fileExtension = Path.GetExtension(fuLHSEntry.PostedFile.FileName);
                string fileLocation = Server.MapPath("~/App_Data/" + fileName);
                fuLHSEntry.SaveAs(fileLocation);

                if (fileExtension == ".xls")
                {
                    connectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + fileLocation + @";Extended Properties=" + Convert.ToChar(34).ToString() + @"Excel 8.0;Imex=1;HDR=Yes;" + Convert.ToChar(34).ToString();
                }
                else if (fileExtension == ".xlsx" || fileExtension == ".xlsm")
                {
                    connectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + fileLocation + @";Extended Properties=" + Convert.ToChar(34).ToString() + @"Excel 12.0;IMEX=2;HDR=Yes;" + Convert.ToChar(34).ToString();
                }

                OleDbConnection con = new OleDbConnection(connectionString);
                OleDbCommand cmd = new OleDbCommand();
                cmd.CommandType = System.Data.CommandType.Text;
                cmd.Connection = con;
                OleDbDataAdapter dAdapter = new OleDbDataAdapter(cmd);
                DataTable dtExcelRecords = new DataTable();
                con.Open();
                DataTable dtExcelSheetName = con.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);
                int count = 0;
                foreach (DataRow dr in dtExcelSheetName.Rows)
                {
                    getExcelSheetName = GetSheetName(dr);
                    if (!string.IsNullOrEmpty(getExcelSheetName))
                    {                        
                        cmd.CommandText = "SELECT * FROM [" + getExcelSheetName + "]";
                        dAdapter.SelectCommand = cmd;
                        if (getExcelSheetName.ToUpper().Contains("LEARNING"))
                        {
                            getExcelSheetName = "LEARNING";
                        }
                        else
                        {
                            getExcelSheetName = "LHS";
                        }
                        dAdapter.Fill(dsData, getExcelSheetName);
                        count++;
                        if (count == 2)
                        {
                            break;
                        }
                    }
                }
                con.Close();
            }
            return dsData;
        }

请帮我解决这个问题。 谢谢, 的Raji

1 个答案:

答案 0 :(得分:0)

从您的代码中可以看出,该表可以有两个可能的名称。

要么它总是与您稍后在阅读时使用的名称相同:

dAdapter.Fill(dsData, "LHS");

或者你可以通过索引来取代它的名字:

var designation = dsData.Tables[0].AsEnumerable().Where(r => Convert.ToString(r["Associate Id"]).Trim() == LHSupdate.AssciateID.Trim());