繁体   English   中英

连接两个对象列表:一个列表中的所有属性,另一个列表中的某些属性

[英]Join two lists of objects: All properties from one list, only certain properties from the other one

我有两个班级:

class Class1
{
    public int ProductId  { get; set; }
    public string ProductName  { get; set; }
    public int Amount  { get; set; }
    public string Category { get; set; }
}

class Class2
{
    public id ProductId  { get; set; }
    public DateTime UpdateTime { get; set; }
    public int ItemState  { get; set; }
    public decimal Price { get; set; }
    public string ImageUrl { get; set; }
}

我为每个班级创建了两个列表:

public List<Class1> listClass1 { get; set; } = new List<Class1>();
public List<Class2> listClass2 { get; set; } = new List<Class2>();

现在我想通过在连接两个列表创建一个新的列表ProductID包含来自所有属性Class1 ,只是UpdateTimeItemStateClass2 做这个的最好方式是什么?

(最终目标是让用户保存当前会话以让他以后继续他的工作,为此我需要完整的listClass1和提到的listClass2属性。想法是在合并列表上使用XmlSerializer并保存它到一个 XML 文件中。要打开该文件,我想对其进行反序列化。如果您有更好的方法让用户保存他的会话,我会全力以赴。)

我建议创建一个代表连接参数集的第三个类。

public class Class1_2
{
    public int ProductId { get; set; }
    public string ProductName { get; set; }
    public int Amount { get; set; }
    public string Category { get; set; }

    public DateTime UpdateTime { get; set; }
    public int ItemState { get; set; }
}

LINQ Join 2 Lists 中描述了如何 加入 2 个列表 所以你最终会得到这样的结果:

List<Class1_2> joinedList = (from item1 in listClass1
                             join item2 in listClass2
                             on item1.ProductId equals item2.ProductId
                             select new Class1_2
                             {
                                 ProductId = item1.ProductId,
                                 Amount = item1.Amount,
                                 ProductName = item1.ProductName,
                                 Category = item1.Category,
                                 ItemState = item2.ItemState,
                                 UpdateTime = item2.UpdateTime
                             }).ToList();

说明:您加入特定属性上的项目。 如果它在两个列表中相等,则获取该项目并使用所选属性构建一个新项目。 连接也可以在没有Class1_2情况下工作,但是您会得到dynamic类型的结果。 新的Class_1_2的优点是您可以将其用于具有定义结构的序列化。

编辑

您还可以在Class1_2使用第二个构造Class1_2

public Class1_2(Class1 c1, Class2 c2)
{
    ProductId = c1.ProductId;
    Amount = c1.Amount;
    ProductName = c1.ProductName;
    Category = c1.Category;
    ItemState = c2.ItemState;
    UpdateTime = c2.UpdateTime;
}

这将把select语句简化为:

select new Class1_2(item1, item2)).ToList();

暂无
暂无

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

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