0

我在编写正确的代码或提出问题时可能是错误的,但我正在寻求以下帮助。

我有一个具有多对多关系的 xml 文件,如下所示:

<ShowRoom>
  <Cars>
    <Car id="1" number="001" name="MyCar" >
      <Parts>
        <Part id="1" />
        <Part id="2" />
      </Parts>
    </Car>
    <Car id="2" number="002" name="YourCar" >
      <Parts>
        <Part id="2" />
        <Part id="3" />
        <Part id="4" />
      </Parts>
    </Car>
  </Cars>
  <Parts>
    <Part id="1" name="Tyre" active="true"/>
    <Part id="2" name="Window" active="true"/>
  </Parts>
</ShowRoom>

与该对象相对应的是 follow

public class Car
{
    private int _id;
    public int Id
    {
        get { return _id; }
        set { _id = value; }
    }

    private string _number;
    public string Number
    {
        get { return _number; }
        set { _number = value; }
    }

    private string _name;
    public string Name
    {
        get { return _name; }
        set { _name = value; }
    }

    private List<Parts> _listParts;
    public List<Parts> ListParts
    {
        get { return _listParts; }
        set { _listParts = value; }
    }
}

我正在尝试的是读取 xml 并在汽车和零件之间加入,所以我会得到汽车对象及其所有零件的详细信息

  IEnumerable<XElement> xCar = xdoc.Element("ShowRoom").Element("Cars").Elements("Car");
                IEnumerable<XElement> xPart = xdoc.Element("ShowRoom").Element("Parts").Elements("Part");
                IEnumerable<Car> car = xCar.Join(
                    xPart,
                    c => c.Element("Parts").Element("Part").Attribute("id").Value,
                    p => p.Attribute("id").Value,
                    (c, p) =>
                    new Cars
                    {
                        Id = int.Parse(c.Attribute("id").Value),
                        Number = (string)c.Attribute("number").Value,
                        Name = (string)c.Attribute("name").Value,

                        ListParts =  
                        { 
                                new Parts
                                    {
                                        Id = int.Parse(p.Attribute("id").Value),
                                        Name = (string)p.Attribute("name").Value,
                                        Active = bool.Parse(p.Attribute("active").Value)
                                    }
                        }
                    });

这里的问题是我不知道如何像上面的代码那样让所有零件都与汽车相撞,这显然是错误的

                        ListParts =  
                        { 
                                new Parts
                                    {
                                        Id = int.Parse(p.Attribute("id").Value),
                                        Name = (string)p.Attribute("name").Value,
                                        Active = bool.Parse(p.Attribute("active").Value)
                                    }

那么如何使用上面相同的代码完成它,或者如果有其他好的方法,请与我分享。

谢谢。

4

1 回答 1

2

我强烈建议建立一个零件字典,然后建立汽车列表:

Dictionary<int, Part> partsById = doc.Root
    .Element("Parts")
    .Elements("Part")
    .Select(p => new Parts
            {
                Id = (int) p.Attribute("id"),
                Name = (string) p.Attribute("name"),
                Active = (bool) p.Attribute("active")
            })
    .ToDictionary(part => part.Id);

请注意,我已重命名PartsPart,因为每个对象仅代表一个部分 - 并且我已经删除了所有解析,使用XAttribute.

然后,当您构建汽车列表时,您可以使用:

...
ListParts = c.Element("Parts")
             .Elements("Part")
             .Select(p => partsById[(int) p.Attribute("Id")])
             .ToList();

您还应该研究自动实现的属性,这会将您的Car类减少到几行代码:

public class Car
{
    public int Id { get; set; }
    public string Number { get; set; }
    public string Name { get; set; }
    public List<Parts> ListParts { get; set; }
}
于 2013-03-28T15:16:36.290 回答