[英]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
对象。 tempInt
和tempDouble
变量用于保存每个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.