DataRow - 如何取消向datatable添加行?

时间:2013-09-25 17:35:28

标签: c# datatable add datarow

我有一个问题。

我有两个循环(一个用于行,一个用于列),用于在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"的列中的单元格值不为空的行(我的意思是“是”)。

最好的方法或最简单的方法是什么?

1 个答案:

答案 0 :(得分:1)

将其更改为:

....
    foreach (string column in columns)
        {
            if (row["Name"] == "")
            {
                row = null;
                break; //--> Add this line
            }
            else
            {
                row[column] = cell;
            }
        }
....