无法从收到的XML文件中获取列表

时间:2013-08-13 08:32:16

标签: c# linq xml-parsing linq-to-xml xmldocument

这是我收到的xml:

<?xml version="1.0" encoding="UTF-8"?>
<mdpr:Data xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:mdpr="http://...">
<mdpr:contactList>
    <mdpr:contact ID="{123456}" classID="Customer">
      <mdpr:Name>data1</mdpr:Name>
      <mdpr:TransportCode>data2</mdpr:TransportCode>
      <mdpr:ZipCode>data3</mdpr:ZipCode>
      <mdpr:City>data4</mdpr:City>
    </mdpr:contact>
    <mdpr:contact ID="{234567}" classID="Customer">
      <mdpr:Name>data5</mdpr:Name>
      <mdpr:TransportCode>data6</mdpr:TransportCode>
      <mdpr:ZipCode>data7</mdpr:ZipCode>
      <mdpr:City>data8</mdpr:City>
    </mdpr:contact>
</mdpr:contactList>
...

以下是我尝试获取所有联系人的方式:

public class Contact
    {
        public string Name { get; set; }
        public string TransportCode { get; set; }
    }
...
XDocument xdoc = XDocument.Load(doc.CreateNavigator().ReadSubtree());

            List<Contact> contacts = (from xml in xdoc.Elements("contactList").Elements("contact")
                                      select new Contact
                              {
                                  Name = xml.Element("Name").Value,
                                  TransportCode = xml.Element("TransportCode").Value
                              }).ToList();

但我一无所获。我在这里做错了什么?

3 个答案:

答案 0 :(得分:1)

尝试指定命名空间

string nmsp = "http://www.w3.org/2001/XMLSchema-instance/"

from xml in xdoc.Elements(nmsp+"contactList").Elements(nmsp + "contact")

答案 1 :(得分:1)

您的xml中声明了mdpr名称空间:

xmlns:mdpr="http://..."

但您只在查询中提供元素的本地名称。例如。您提供了contactList名称,但元素的全名是mdpr:contactList。这就是找不到任何东西的原因。

您应该为命名空间定义XNamespace,并使用它来创建元素的全名:

XNamespace mdpr = "http://...";
var contacts = from c in xdoc.Root.Element(mdpr + "contactList")
                                  .Elements(mdpr + "contact")
               select new Contact {
                   TransportCode = (string)c.Element(mdpr + "TransportCode"),
                   Name = (string)c.Element(mdpr + "Name")
               };

contactList也不是文档的根。您应该在Root下搜索。

答案 2 :(得分:1)

XDocument xdoc = XDocument.Load(doc.CreateNavigator().ReadSubtree());
var ns = xdoc.Root.Name.Namespace;
List<Contact> contacts = (from xml in xdoc.Root.Elements(ns +"contactList").Elements(ns +"contact")
                          select new Contact
                  {
                      Name = xml.Element(ns +"Name").Value,
                      TransportCode = xml.Element(ns +"TransportCode").Value
                  }).ToList();