好吧,您可以通过执行以下操作将行放入列表中:
using System.Linq;
...
var rowsArray = new DataRow[dt.Rows.Count];
dt.Rows.CopyTo(rowsArray, 0);
var rowsList = rowsArray.ToList();
但就根据您指定的标准进行过滤而言,我不确定,因为这里没有足够的信息来解决这个问题。
顺便说一句,您实际上可以DefaultView
使用以下方法过滤:
dt.DefaultView.RowFilter = "some filter here";
然后只需绑定到DefaultView
. 您可以在此处找到相关文档。
已编辑问题的更新
好的,根据您的需要,这是一个可以满足您需求的工作控制台应用程序。简而言之,您需要实现EqualityComparer
并在上面的代码中添加一行Distinct
,即与您的比较器的调用。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace ConsoleApplication11
{
class Program
{
static void Main(string[] args)
{
var list = new List<object[]>
{
new object[] {"tamilnadu","capital",2000000},
new object[] {"other","capital",9490384},
new object[] {"tamilnadu","capital",2000000}
};
foreach (var item in list)
{
Console.WriteLine(string.Format("{0} | {1} | {2}", item[0], item[1], item[2]));
}
Console.WriteLine();
Console.WriteLine();
var distinctList = list.Distinct(new MyArrayComparer());
foreach (var item in distinctList)
{
Console.WriteLine(string.Format("{0} | {1} | {2}", item[0], item[1], item[2]));
}
}
class MyArrayComparer : EqualityComparer<object[]>
{
public override bool Equals(object[] x, object[] y)
{
if (x.Length != y.Length) { return false; }
for (int i = 0; i < x.Length; i++)
{
if (!x[i].Equals(y[i]))
{
return false;
}
}
return true;
}
public override int GetHashCode(object[] obj)
{
return 0;
}
}
}
}