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