繁体   English   中英

Linq Groupby具有相同名称的多个列(匿名类型不能具有具有相同名称的多个属性)

[英]Linq Groupby multiple columns with the same name (An anonymous type cannot have multiple properties with the same name)

我有一个对象数组,每个对象有3个客户端,每个客户端都有一个客户端代码和一个客户端名称。 我想使用C#Linq按客户端代码对不同对象进行分组。

对象[0]:客户端“ pickupFrom”具有“ clientCode”客户端“ loadAt”具有“ clientCode”客户端“ deliverTo”具有“ clientCode”

object [1]:客户端“ pickupFrom”具有“ clientCode”客户端“ loadAt”具有“ clientCode”客户端“ deliverTo”具有“ clientCode”

我想按这些客户端分组,并获得具有一个对象的数组,因为这些客户端是相同的。

使用Linq我可以做到:

Objects[] GroupedDistinct = 
       ungroupedObjects.GroupBy(line => new { line.pickupFrom.clientCode,
                                              line.LoadAt.clientCode,
                                              line.deliverTo.clientCode })
                       .Select(x => x.First())
                       .ToArray();

这里的问题是,当将这些参数传递给groupby时,我不能多次传递clientCode,因为它多次定义了名称为clientCode的字符串,即使它不是来自同一客户端对象。

错误是“匿名类型不能具有相同名称的多个属性”,我理解您不能多次传递相同的字符串名称,但这就是使用clientCode完成这些对象(客户端)的方式。 有没有解决的办法?

只是给他们唯一的名字。 另外,我认为您打算使用line而不是object

Objects[] GroupedDistinct = ungroupedObjects
    .GroupBy(line => new { 
        PickFromClientCode = line.pickupFrom.clientCode,
        LoadAtClientCode = line.LoadAt.clientCode,
        DeliverToClientCode = line.deliverTo.clientCode })
    .Select(x => x.First())
    .ToArray();

暂无
暂无

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

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