获取嵌套元素Linq到XML

时间:2014-06-11 19:30:10

标签: vb.net linq linq-to-xml

我的XML

<?xml version="1.0" encoding="utf-8"?>
<metadata created="2014-05-15T12:26:07.701Z" xmlns="http://site/cu-2.0#" xmlns:ext="http://site/cu/b-2.0">
  <customer-list count="47" offset="0">
    <customer id="7123456" type="Cust" ext:mark="1">
      <name>Tony Watt</name>
      <sort-name>Watt, Tony</sort-name>
      <gender>male</gender>
      <country>US</country>
      <knownAs-list>
        <knownAs locale="ko" sort-name="Tony Watt"</knownAs>
        <knownAs locale="ja" sort-name="Watt Tony"</knownAs>
      </knownAs-list>
      <tag-list>
          <begin>Country</begin>
          <tag count="1">
          <name>usa</name>
      </tag-list>
 </customer>
  <customer id="9876543" type="Cust" ext:mark="2">
....
</customer-list>

所以我有一些代码可以获取所有数据。我更进一步使用匿名类型并将值添加到类中,如下所示

Dim c = From cust As XElement In XDoc.Descendants(ns + "customer")
              Select New Customer() With {.Name = cust.Element(ns + "name"),
                                        .Surname = CStr(cust.Element(ns + "surname")),
                                        .Id = cust.Attribute("id"),
                                        .Tag = CStr(cust.Element("tag-list").Element("begin"))}

上面的代码从XML返回数据,但添加了这行代码

.Tag = CStr(cust.Element("tag-list").Element("begin"))

抛出异常,“对象引用未设置为对象的实例”。现在这里有两种可能性

  1. 我的代码有错误(从'tag-list'元素中检索'begin')
  2. 我知道有些tag-list元素没有嵌套的begin元素,所以可能会增加一些混乱。我添加了Cstr来克服这一点,但不确定这是否足够?
  3. 在阅读MSDN之后,它似乎正在使用.Descendants(Xdoc.Descendants)将获取所有元素的所有数据,其中Elements将数据返回到我所声明的路径,因此我可以告诉数据'应该'是可用上面的代码。任何人都可以协助我从标签列表中获取开始数据吗?

1 个答案:

答案 0 :(得分:1)

缺少XML名称空间声明。使用

.Tag = CStr(cust.Element(ns + "tag-list").Element(ns + "begin"))