从DataTable中删除行

时间:2015-04-08 11:04:27

标签: c# linq datatable

我需要从列中具有特定值的DataTable dt中删除行。 在删除它们之前,我将它们复制到另一个DataTable dt2nd。

看起来像这样

        for (int i = dt.Rows.Count - 1; i >= 0; i--)
        {
            DataRow row = dt.Rows[i];

            if (row["Column2"].ToString() == "This Value")
            {
                dt2nd.ImportRow(row); //Copy
                dt.Rows.Remove(row); //Remove
            }
            if (row["Column2"].ToString() == "Other Value")
            {
                dt2nd.ImportRow(row); //Copy
                dt.Rows.Remove(row); //Remove
            }
            //This continues with more if
        }

但我收到错误消息

  

“附加信息:此行已从表格中删除   没有任何数据。 BeginEdit()将允许创建新数据   在这一行。“。

许多行可以具有“此值”或“其他值”。

==“”值可以是很多不同的值,所以如果我这样做会有很多IF语句。

有没有什么好方法可以用LINQ或其他方式做到这一点?

3 个答案:

答案 0 :(得分:1)

此代码可以使用:

for (int i = dt.Rows.Count - 1; i >= 0; i--)
    {
        DataRow row = dt.Rows[i];

        if (row["Column2"].ToString() == "This Value")
        {
            dt2nd.ImportRow(row); //Copy
            dt.Rows.Remove(row); //Remove
            continue;
        }
        if (row["Column2"].ToString() == "Other Value")
        {
            dt2nd.ImportRow(row); //Copy
            dt.Rows.Remove(row); //Remove
            continue; 
        }
        //This continues with more if
    }

或者您可以使用switch语句而不是所有ifs,如果

,则使用else
for (int i = dt.Rows.Count - 1; i >= 0; i--)
    {
        DataRow row = dt.Rows[i];

        if (row["Column2"].ToString() == "This Value")
        {
            dt2nd.ImportRow(row); //Copy
            dt.Rows.Remove(row); //Remove
        }
        else if (row["Column2"].ToString() == "Other Value")
        {
            dt2nd.ImportRow(row); //Copy
            dt.Rows.Remove(row); //Remove
        }
        //This continues with more else if
    }

for (int i = dt.Rows.Count - 1; i >= 0; i--)
    {
        DataRow row = dt.Rows[i];

        switch(row["Column2"].ToString()){
        case "This Value":
        {
            dt2nd.ImportRow(row); //Copy
            dt.Rows.Remove(row); //Remove
            break;
        }
        case "Other Value":
        {
            dt2nd.ImportRow(row); //Copy
            dt.Rows.Remove(row); //Remove
            break; 
        }
        //This continues with more case
    }

但您也可以在数据表上使用select,并输出需要移出的所有行。像这样的东西:

dt.select("Column2 == 'This value' or ...");

它将返回满足条件的行。见这里的例子: http://www.dotnetperls.com/datatable-select

但如果操作始终相同,则可以缩短代码:

for (int i = dt.Rows.Count - 1; i >= 0; i--)
    {
        DataRow row = dt.Rows[i];

        if (
               (row["Column2"].ToString() == "This Value") ||
               (row["Column2"].ToString() == "Other Value") //more checks
           )
        {
            dt2nd.ImportRow(row); //Copy
            dt.Rows.Remove(row); //Remove
        }
    }

for (int i = dt.Rows.Count - 1; i >= 0; i--)
{
    DataRow row = dt.Rows[i];

    switch(row["Column2"].ToString()){
    case "This Value":
    case "Other Value": //more case values
    {
        dt2nd.ImportRow(row); //Copy
        dt.Rows.Remove(row); //Remove
        break;
    }
}

答案 1 :(得分:1)

你可以试试这个......

        var checkValues = new string[]  { "Some value1", "Some value3" };
        DataTable dt = new DataTable();
        DataTable dt1 = new DataTable();
        dt.Columns.Add("Column1");
        dt.Columns.Add("Column2");
        dt.Columns.Add("Column3");
        dt.Rows.Add(new string[] {"Some value1", "Some value2", "Some value3" });
        dt.AsEnumerable().ToList().ForEach(x =>
            {
                if (checkValues.Contains(x["Column1"]))
                {
                    dt1.ImportRow(x);
                    dt.Rows.Remove(x);
                }
            });

答案 2 :(得分:1)

var valuesToBeChecked = new String[] { "value1", "value2" };
        var x = from y in dt.AsEnumerable()
                where valuesToBeChecked.Any(t => valuesToBeChecked.Contains(y["Column2"].ToString()))
                select y;
        var z = dt.AsEnumerable().Except(x);

然后,您可以将z复制到您想要的datatable

DataTable dt2 = z.CopyToDataTable();