datagridview中的列表给出了System.InvalidCastException

时间:2017-02-02 11:48:59

标签: c# class for-loop datagridview

我有一个名为GetKoord的类,我想在其中读取datagridview并将其放入列表中。我创建了一个类vertEl,因为我首先得到了一个带有递归stackoverflowexception的错误。

当我在公共部分类中尝试从vertElementerDgv创建列表时,会出现此代码的问题。我班级中添加列表项的循环不能正常工作并提供异常。

我感谢所有帮助!如果缺少某些信息,请告诉我,我会尽我所能提供。

GetKoord getKoord = new GetKoord();


    //Opens the file dialog and assigns file path to Textbox
    OpenFileDialog browseButton = new OpenFileDialog();
    private void browse_Click(object sender, EventArgs e)
    {
        DGV = nylpDgv;
        browseButton.Filter = "Excel Files |*.xlsx;*.xls;*.xlsm;*.csv";
        if (browseButton.ShowDialog() == DialogResult.OK)
        {
            ExcelPath.Text = browseButton.FileName;
            fileExcel = ExcelPath.Text;
            //SetAttributeValue(ExcelPath, fileExcel);
            //nylp();

            /*
            ////IMPORTERER 10TAB-DATA FRA EXCEL TIL DATAGRIDVIEW////
            tenTabLine.fileExcel = fileExcel;
            tenTabLine.tenTab(tenTabDgv);
            */            

            ////IMPORTERER NYLPDATA TIL DATAGRIDVIEW////
            nylpLine.fileExcel = fileExcel;
            nylpLine.nylpData(nylpDgv);

            ////TAR DATA I NYLPDGV DATAGRIDVIEW OG BEREGNER VERTIKALE ELEMENTER////
            vertElementer.vertBueDGV(nylpDgv, vertElementerDgv);

            ////HENTER KOORDINATER////
            var TEST = getKoord.vertList(vertElementerDgv); //THIS IS CAUSING ERROR
            MessageBox.Show(TEST[5].elNr.ToString());


        }
        else return;
    }

GetKoord类和vertEl类如下:

class GetKoord
{

    List<vertEl> vertTEST = new List<vertEl>(); 

    public List<vertEl> vertList(DataGridView VertElementer)
    {
        for (int i = 0; i<VertElementer.Rows.Count - 1; i++)
        {
            vertTEST.Add(new vertEl
            {
                elNr = (int)VertElementer.Rows[i].Cells[0].Value,
                p1 = (double)VertElementer.Rows[i].Cells[1].Value,
                p2 = (double)VertElementer.Rows[i].Cells[2].Value,
                z1 = (double)VertElementer.Rows[i].Cells[3].Value,
                z2 = (double)VertElementer.Rows[i].Cells[4].Value,
                heln1 = (double)VertElementer.Rows[i].Cells[5].Value,
                heln2 = (double)VertElementer.Rows[i].Cells[6].Value
            });

        }

        return vertTEST;
    }



    /*
    public double zKoord(double pNr)
    {

       // zKoord() = 

        return zKoord(pNr);

    }
    */

}

class vertEl
{
    private int _elNr;
    private double _p1;
    private double _p2;
    private double _z1;
    private double _z2;
    private double _nylpRad;
    private double _heln1;
    private double _heln2;

    public int elNr
    {
        get { return _elNr; }
        set { _elNr = value; }
    }

    public double p1
    {
        get { return _p1; }
        set { _p1 = value; }
    }

    public double p2
    {
        get { return _p2; }
        set { _p2 = value; }
    }

    public double z1
    {
        get { return _z1; }
        set { _z1 = value; }
    }

    public double z2
    {
        get { return _z2; }
        set { _z2 = value; }
    }

    public double nylpRad
    {
        get { return _nylpRad; }
        set { _nylpRad = value; }
    }

    public double heln1
    {
        get { return _heln1; }
        set { _heln1 = value; }
    }

    public double heln2
    {
        get { return _heln2; }
        set { _heln2 = value; }
    }
}

2 个答案:

答案 0 :(得分:0)

Excel的数据类型并不总是您期望的并且您正在投入的数据类型。您必须自己转换值:

vertTEST.Add(new vertEl
{
    elNr = Convert.ToInt32(VertElementer.Rows[i].Cells[0].Value),
    p1 = Convert.ToDouble(VertElementer.Rows[i].Cells[1].Value),
    p2 = Convert.ToDouble(VertElementer.Rows[i].Cells[2].Value),
    z1 = Convert.ToDouble(VertElementer.Rows[i].Cells[3].Value),
    z2 = Convert.ToDouble(VertElementer.Rows[i].Cells[4].Value),
    heln1 = Convert.ToDouble(VertElementer.Rows[i].Cells[5].Value),
    heln2 = Convert.ToDouble(VertElementer.Rows[i].Cells[6].Value)
});

答案 1 :(得分:0)

根据您的评论和代码显示的内容,我相信您会从Value次转化中收到此错误。例如,如果DataGridView中的一个单元格为空,并且您尝试将此“Empty”值转换为double,则会出现此错误。

检查这些空值和错误的数字格式应该以任何方式完成,尤其是在尝试将字符串转换为数字时。字符串总是有可能不是数字。假设值都是正确的,另一种可能性是DataGridView中添加的行。所以在这里猜测,我会建议两种方法来帮助找出这个错误的来源。首先,检查空值并使用tryParse来帮助清除错误的int / double值。还可以使用foreach循环遍历行。

首先创建一个新列表来保存vertEl个对象。 tempInttempDouble变量用于保存每个tryParse结果。您可能已经看到tryParse语句中使用的if,如下所示

Int result = 0;
If (int.tryParse(someString, out result) {
  // here the parse was successful – result is a valid number
}
else {
  //  either null or bad number format – result is still valid and is set to zero.
}

这是通过添加对空单元格的检查或单元格中的值是错误数字格式来确定错误来源的一种方法。下面的代码只是忽略错误值,并为这些错误值设置默认值零(0)。如果字符串为空或者数字格式无效,tryParse将返回false。在这种情况下,我们真的不在乎哪一个;我们将简单地将此值设置为零(0),这是解析失败时{out}变量中tryParse返回的值。因此,检查它是否失败或成功是不必要的。如果失败,返回的数字将为零。希望这会有所帮助。

private List<vertEl> GetVertList() {
  List<vertEl> vertTEST = new List<vertEl>();
  int tempInt = 0;
  double tempDouble = 0.0;
  foreach (DataGridViewRow row in VertElementer.Rows) {
    if (!row.IsNewRow) {
      vertEl vert1 = new vertEl();
      int.TryParse(row.Cells[0].Value.ToString(), out tempInt);
      vert1.elNr = tempInt;
      double.TryParse(row.Cells[1].Value.ToString(), out tempDouble);
      vert1.p1 = tempDouble;
      double.TryParse(row.Cells[2].Value.ToString(), out tempDouble);
      vert1.p2 = tempDouble;
      double.TryParse(row.Cells[3].Value.ToString(), out tempDouble);
      vert1.z1 = tempDouble;
      double.TryParse(row.Cells[4].Value.ToString(), out tempDouble);
      vert1.z2 = tempDouble;
      double.TryParse(row.Cells[5].Value.ToString(), out tempDouble);
      vert1.heln1 = tempDouble;
      double.TryParse(row.Cells[6].Value.ToString(), out tempDouble);
      vert1.heln2 = tempDouble;
      vertTEST.Add(vert1);
    }
  }
  return vertTEST;
}