如果列包含数组中的任何元素,则过滤数据表

时间:2020-01-30 16:38:46

标签: c# vb.net linq datatable

我有一个这样的数据表

ColA  ColB
1     OneThree
2     FourTwo
3     EightNine
4     ThreeEightFive
5     SevenNine

并且子字符串在另一个数组("Two","Eight", "Three")

如何使用ColB过滤DataTable并获取包含数组中任何子字符串的行?数组可能有n个子字符串。

是否可以使用Linq而不循环遍历每个数组元素并使用CONTAINS关键字检查colB?

3 个答案:

答案 0 :(得分:1)

这将返回包含列表中所有值的所有ColB值。

var dt = // your datatable
var list = new List<string>{ "Two", "Eight", "Three" }; 
var matches = dt.AsEnumerable()
                .Where(dr => list.Any(l => dr.Field<string>("ColB").Contains(l)))
                .Select(r => r.Field<string>("ColB"))
                .ToList();

请注意,Linq仍在后台执行循环。这可能不是很有效(由于Where/Any),特别是在大型数据集上。

如果您想返回DataTable,请使用CopyToDataTable()

var matches = dt.AsEnumerable()
                .Where(dr => list.Any(l => dr.Field<string>("ColB").Contains(l)))
                .CopyToDataTable();

答案 1 :(得分:1)

您可以使用如下所示的LINQ来查询数据表

DataTable dt = new DataTable();
            dt.Columns.Add("ColA", typeof(int));
            dt.Columns.Add("ColB", typeof(string));
            dt.AcceptChanges();

            var r1 = dt.NewRow();
            r1["ColA"] = 1;
            r1["ColB"] = "OneThree";
            dt.Rows.Add(r1);

            var r2 = dt.NewRow();
            r2["ColA"] = 2;
            r2["ColB"] = "FourTwo";
            dt.Rows.Add(r2);

            var r3 = dt.NewRow();
            r3["ColA"] = 3;
            r3["ColB"] = "EightNine";
            dt.Rows.Add(r3);

            var r4 = dt.NewRow();
            r4["ColA"] = 4;
            r4["ColB"] = "ThreeEightFive";
            dt.Rows.Add(r4);

            var r5 = dt.NewRow();
            r5["ColA"] = 5;
            r5["ColB"] = "SevenNine";
            dt.Rows.Add(r5);

            dt.AcceptChanges();

            var subArray = new string[3] { "Two", "Eight", "Three" };

            var query = from r in dt.AsEnumerable()
                        where  subArray.Any(s=> r.Field<string>("ColB").IndexOf(s,StringComparison.InvariantCultureIgnoreCase)>-1)
                        select r.Field<string>("ColB");
            foreach (var item in query)
            {
                Console.WriteLine(item);
            }

答案 2 :(得分:0)

如果我很了解您需要这样的话。 用填充的DataTable更改MyDataTable并根据需要处理代码。

Dim containsMyWords As Func(Of String, Boolean) = Function(entryS As String)
                                                      Dim myWords() As String = {"r1", "r2", "r3", "r4", "r5", "r6"}
                                                      If myWords.Contains(entryS) Then Return True
                                                      Return False
                                                  End Function

Dim listRows = From dtR As DataRow In MyDataTable.AsEnumerable
               Where containsMyWords(CType(dtR.Item("ColB"), String))

For Each mRow In listRows
    Console.WriteLine(Join(mRow.ItemArray, "~"))
Next