繁体   English   中英

使用LINQ从列表中获取具有特定属性最大值的对象

[英]Get the objects with the maximum value for a specific property from a list using LINQ

我有一个Beam对象列表。 每个Beam类都有XY属性作为坐标,并且还具有Height属性。

现在这是我的初始列表:

List1 = {beam1, beam2, beam3, beam4}

beam1 = {X = 0, Y = 0, Height = 40}
beam2 = {X = 200, Y = 0, Height = 40}
beam3 = {X = 200, Y = 0, Height = 60}
beam4 = {X = 400, Y = 0, Height = 40}

如您所见, beam2beam3在同一点,我想要一个列表,在该列表中,我在每个不同的点仅具有最大Height的波束。

因此,使用LINQ的最终列表为:

 List2 = {beam1, beam3, beam4}

您可以使用GroupBy根据XY对它们进行分组,然后从每个组中选择具有最大高度的项目:

beams.GroupBy(b => new { b.X, b.Y })
 .Select(g => g.First(x => x.Heigth == g.Max(h => h.Height)))
 .ToList();

我个人将使用MaxBy方法获得最大光束。 高度:

beams.GroupBy(b => new { b.X, b.Y })
 .Select(g => g.MaxBy(x => x.Heigth))
 .ToList();

尝试这个:-

var query = List1.GroupBy(x => new { x.X, x.Y }).Select(x => x.First(y => y.Height == x.Max(z => z.Height)));

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM