Linq to XML вложенный запрос - PullRequest
5 голосов
/ 22 марта 2010

У меня проблема с получением запроса LINQ.У меня есть этот XML:

<devices> 
   <device id ="2142" name="data-switch-01">
     <interface id ="2148" description ="Po1"/>
   </device>
   <device id ="2302" name="data-switch-02">
     <interface id ="2354" description ="Po1"/>
     <interface id ="2348" description ="Gi0/44" />
   </device>
 </devices>

И этот код:

var devices = from device in myXML.Descendants("device")
              select new
              {
                  ID = device.Attribute("id").Value,
                  Name = device.Attribute("name").Value,
               };

foreach (var device in devices)
{
    Device d = new Device(Convert.ToInt32(device.ID), device.Name);

    var vIfs = from vIf in myXML.Descendants("device")
                  where Convert.ToInt32(vIf.Attribute("id").Value) == d.Id
                  select new
                  {
                      ID = vIf.Element("interface").Attribute("id").Value,
                      Description = vIf.Element("interface").Attribute("description").Value,
                  };
    foreach (var vIf in vIfs)
    {
        DeviceInterface di = new DeviceInterface(Convert.ToInt32(vIf.ID), vIf.Description);
        d.Interfaces.Add(di);
    }

    lsDevices.Add(d);
}

Мой объект Device содержит список DeviceInterfaces, который мне нужно заполнить из XML.На данный момент мой код заполняет только первый интерфейс, все последующие игнорируются, и я не могу понять, почему.

Буду также признателен за любые комментарии о том, является ли это правильным способом сделать это.Вложенные циклы foreach кажутся мне немного беспорядочными

Приветствия

Ответы [ 2 ]

12 голосов
/ 22 марта 2010
IEnumerable<Device> devices = 
  from device in myXML.Descendants("device")
  select new Device(device.Attribute("id").Value, device.Attribute("name").Value)
  {
     Interfaces = (from interface in device.Elements("Interface")
                   select new DeviceInterface(
                        interface.Attribute("id").Value,
                        interface.Attribute("description").Value)
                  ).ToList() //or Array as you prefer
  }

Основным моментом здесь является то, что вы делаете своего рода «отбор» на устройстве (которое является Descendant), ища все элементы Interface, которые в нем содержатся.

Создает новый DeviceInterface для каждого «интерфейса» под каждым устройством.

1 голос
/ 22 марта 2010

Быстро и грязно

var query = from device in document.Descendants("device")
            select new
            {
                ID = device.Attribute("id").Value,
                Name = device.Attribute("name").Value,
                Interfaces = from deviceInterface in device.Descendants("interface")
                             select new
                             {
                                 ID = deviceInterface.Attribute("id").Value,
                                 Description = deviceInterface.Attribute("description")
                             }
            };
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...