繁体   English   中英

datagridview中的列表给出了System.InvalidCastException

[英]List from datagridview gives System.InvalidCastException

我有一个名为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; }
    }
}

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)
});

根据您的注释和代码显示的内容,我相信您是从Value转换之一中得到此错误的。 例如,如果DataGridView中的单元格之一为空,而您尝试将此“ Empty”值强制转换为双精度值,则会收到此错误。

无论哪种方式都应该检查这些空值和错误的数字格式,但是特别是在尝试将字符串转换为数字时。 字符串很可能不是数字。 假设所有值都是正确的,另一种可能性是在DataGridView添加行。 因此,仅在此处进行猜测,我将建议两种方法来帮助查找此错误的来源。 首先,检查空值,并使用tryParse帮助清除错误的int / double值。 也可以使用foreach行。

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

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)。 如果字符串为null或数字格式无效,则tryParse将返回false。 在这种情况下,我们真的不在乎哪个。 我们将简单地将此值设置为零(0),这是解析失败时tryParse在其out变量中返回的值。 因此,无需检查它是否成功。 如果失败,则返回的数字将为零。 希望这可以帮助。

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;
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM