我刚刚开始学习 linq 和 lambda 表达式,它们似乎非常适合在复杂的对象集合中查找重复项,但我有点困惑,希望有人能帮助我回到快乐编码的道路上.
我的对象的结构类似于 list.list.uniqueCustomerIdentifier
我需要确保整个复杂对象中没有重复的 uniqueCustomerIdentifier。如果有重复项,我需要确定哪些重复项并返回重复项列表。
我刚刚开始学习 linq 和 lambda 表达式,它们似乎非常适合在复杂的对象集合中查找重复项,但我有点困惑,希望有人能帮助我回到快乐编码的道路上.
我的对象的结构类似于 list.list.uniqueCustomerIdentifier
我需要确保整个复杂对象中没有重复的 uniqueCustomerIdentifier。如果有重复项,我需要确定哪些重复项并返回重复项列表。
var result =
myList
.SelectMany(x => x.InnerList)
.Select(y => y.uniqueCustomerIdentifier)
.GroupBy(id => id)
.Where(g => g.Skip(1).Any())
.Select(g => g.Key)
.ToList()
有一个 linq 运算符 Distinct(),如果您只需要 id,它允许您过滤到一组不同的记录。如果你已经设置你的类来覆盖等于你或者有一个IEqualityComparer你可以直接调用 Distinct 扩展方法来从列表中返回唯一的结果。作为额外的奖励,您还可以使用 Union 和 Intersect 方法在两个列表之间合并或过滤。
另一种选择是按 id 分组,然后选择第一个元素。
var results = from item in list
group item by item.id into g
select g.First();
如果要展平两个列表层次结构,请使用SelectMany
方法展平IEnumerable<IEnumerable<T>>
into IEnumerable<T>
。