我有一个问题。
我有两个循环(一个用于行,一个用于列),用于在DataTable
中创建数据。我想检查名为"Name"
的列的单元格是否为空,如果它为空,则不要添加此行。这是一个问题:如何取消添加行?
得到一些代码:
for (int i = 0; i < data.Count(); i++)
{
cell = data.ElementAt(i);
DataRow row;
row = dataTable.NewRow();
foreach (string column in columns)
{
if (row["Name"] == "")
{
row = null;
}
else
{
row[column] = cell;
}
}
if (row != null)
{
dataTable.Rows.Add(row);
}
}
但是在下一个循环开始后,它会抛出NullException: Object reference not set to an instance of an object.
通常我想将Rows添加到DataTable,只有那些名为"Name"
的列中的单元格值不为空的行(我的意思是“是”)。
最好的方法或最简单的方法是什么?
答案 0 :(得分:1)
将其更改为:
....
foreach (string column in columns)
{
if (row["Name"] == "")
{
row = null;
break; //--> Add this line
}
else
{
row[column] = cell;
}
}
....