我有一个这样的数据表
ColA ColB
1 OneThree
2 FourTwo
3 EightNine
4 ThreeEightFive
5 SevenNine
并且子字符串在另一个数组("Two","Eight", "Three")
如何使用ColB
过滤DataTable并获取包含数组中任何子字符串的行?数组可能有n个子字符串。
是否可以使用Linq而不循环遍历每个数组元素并使用CONTAINS关键字检查colB?
答案 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