好了伙计们。我有一个包含两个属性的列表: ID和Status。(前)
1001发运
1002发运
1003发运
1003取消
从这个列表中,我需要得到所有的,除了有‘取消’状态的被欺骗的项目。本质上,看看他们是否被欺骗(只会被欺骗一次),如果是的话,不要在新的列表中包括“取消的”一个。所以新的列表应该包含1001,1002和1003。
所以如果我有:
1001取消
1002取消
1003取消
1004取消
清单将包含1001、1002、1003和1004。我可以在C#中使用linq构造这个初始列表(如“Items.GroupBy(Product=> new { product.ProductID,product.Status }).ToList()”),但不能再继续了。任何帮助都将不胜感激。谢谢。
发布于 2017-03-28 23:26:51
根据您指定的规则,简单地使用Distinct()选择唯一的产品ids将完成以下工作:
Items.Select(product => product.ProductID).Distinct()这为您提供了第一个示例的1001, 1002, 1003和第二个示例的1001, 1002, 1003, 1004。
如果不希望选择最后状态为已取消和时间线的产品的in,则仅以初始列表中的项目顺序表示:
Items.GroupBy(product => product.ProductID)
.Where(g => g.Last().Status != "Cancelled")
.Select(g => g.Key)https://stackoverflow.com/questions/43081561
复制相似问题