使用Linq或Lambda表达式检查复杂对象中的重复项

使用Linq或Lambda表达式检查复杂对象中的重复项,linq,lambda,linq-to-objects,Linq,Lambda,Linq To Objects,我刚刚开始学习linq和lambda表达式,它们似乎非常适合在复杂对象集合中查找重复项,但我有点困惑,希望有人能帮助我回到快乐编码的道路上 我的对象的结构类似于list.list.uniqueCustomerIdentifier 我需要确保在整个复杂对象中没有重复的uniqueCustomerIdentifier。如果存在重复项,我需要识别哪些是重复项并返回重复项列表。有一个linq操作符Distinct(),如果您只需要ID,它允许您筛选到一组不同的记录。如果您已将类设置为覆盖等于您的值或具有

我刚刚开始学习linq和lambda表达式,它们似乎非常适合在复杂对象集合中查找重复项,但我有点困惑,希望有人能帮助我回到快乐编码的道路上

我的对象的结构类似于list.list.uniqueCustomerIdentifier


我需要确保在整个复杂对象中没有重复的uniqueCustomerIdentifier。如果存在重复项,我需要识别哪些是重复项并返回重复项列表。

有一个linq操作符Distinct(),如果您只需要ID,它允许您筛选到一组不同的记录。如果您已将类设置为覆盖等于您的值或具有一个值,则可以直接调用Distinct扩展方法从列表中返回唯一的结果。另外,还可以使用Union和Intersect方法在两个列表之间合并或过滤

另一个选项是按id分组,然后选择第一个元素

var results = from item in list
              group item by item.id into g
              select g.First();

如果要展平这两个列表层次结构,请使用
SelectMany
方法将
IEnumerable
展平为
IEnumerable

  • 解包层次结构
  • 将每个元素投影到其唯一ID属性
  • 把这些证件分组
  • 按包含多个元素的组筛选组
  • 将每个组投影到组的密钥(返回到uniqueID)
  • 枚举查询并将结果存储在列表中

您可以跳过。选择(y=>y.uniqueCustomerIdentifier)并改用.GroupBy(y=>y.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()