我想使用 linq to object 来删除重复的记录。
我希望最终列表将包含具有最新日期的唯一记录。
我有以下列表
AId BId C(date)
**1 2 24/5/2015**
3 6 24/5/2015
**1 2 23/5/2015** (Need To Remove)
我想删除记录 3。
有什么建议吗?
您可以使用 GroupBy
,然后使用 Select
和 OrderByDescending
对日期进行排序。
public class Item
{
public int Aid {get;set;}
public int Bid {get;set;}
public DateTime CDate {get;set;}
}
void Main()
{
var items = new List<Item>
{
new Item { Aid = 1, Bid = 2, CDate = new DateTime(2015, 5, 24)},
new Item { Aid = 3, Bid = 6, CDate = new DateTime(2015, 5, 24)},
new Item { Aid = 1, Bid = 2, CDate = new DateTime(2015, 5, 23)},
};
var result = items.GroupBy(i => i.Aid)
.Select(group =>
new { Key = group.Key,
Items = group.OrderByDescending(x => x.CDate) })
.Select (g => g.Items.First());
result.Dump();
}