Дезертициализация файла xml или анализ с использованием linq для xml

Упрощенный XML-файл мне нужно декодировать:

    <?xml version="1.0" encoding="UTF-8"?>
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
   <soap:Body>
      <ns2:deliverylistResponse xmlns:ns2="http://tdriverap3.wsbeans.iseries/">
         <return>
            <COUNT>3</COUNT>
            <DELIVERIES>
               <ADD1>1300 address 1</ADD1>
               <CITY>NICE CITY</CITY>
               <ZIP>85705</ZIP>
            </DELIVERIES>
            <DELIVERIES>
               <ADD1>40 S PINAL PKWY AVE</ADD1>
               <CITY>FLORENCE</CITY>
               <ZIP>85132</ZIP>
            </DELIVERIES>
            <DELIVERIES>
               <ADD1>1825 EAST MAIN</ADD1>
               <CITY>CHANDLER</CITY>
               <ZIP>85286</ZIP>
            </DELIVERIES>
            <ERRORCODE/>
            <RUNDATE>09/26/2018</RUNDATE>
         </return>
      </ns2:deliverylistResponse>
   </soap:Body>
</soap:Envelope>

Я использую следующее, чтобы попробовать и декодировать каждый из отдельных адресов в коде.

Я не могу понять, как получить к ним доступ.

XElement xelement = XElement.Load(@"e:	estX2.xml");
        IEnumerable<XElement> addresses = xelement.Elements();

        foreach (var address in addresses)
        {
            Console.WriteLine(address);
            Console.WriteLine(address.Element("CITY").Value);

        }

Первая запись работает (выводит все дерево XML), вторая говорит: «System.Xml.Linq.XContainer.Element (...) возвращен null» - я попытался использовать DELIVERIES, COUNT, Body и т. Д. ...

Очевидно, я не говорю правильно, как пересечь структуру, но я не знаю, как идти дальше.

ОБНОВЛЕНИЕ: Благодаря некоторой помощи я выяснил, как это сделать с помощью Linq. Я все равно хотел бы десериализовать его, если у кого есть указатель. Я последовал за несколькими учебниками, но несколько уровней этого XML, похоже, отбрасывают меня.

Я создал класс для хранения данных, но это насколько мой успех в этом пути.

Спасибо, Джо

Всего 1 ответ


Спасибо, Crowcoder - это то, с чем я столкнулся, и это сработает. Однако у реального XML-файла имеется около 60 полей, поэтому это не так хорошо, как использование процедуры десериализации, но я могу, по крайней мере, продвигаться вперед с проектом.

XElement xelement = XElement.Load(@"e:	estx2.xml");

            IEnumerable<XElement> textSegs =
                 from seg in xelement.Descendants("DELIVERIES")
                  select seg;

            foreach (var address in textSegs)
            {
                Console.WriteLine(address.Element("ADD1").Value);
                Console.WriteLine(address.Element("CITY").Value);
                Console.WriteLine(address.Element("ZIP").Value);

            }


            Console.ReadKey();

Есть идеи?

10000