2

我使用以下代码来搜索元素的数量,并且只有在没有默认路径的情况下才搜索成功:

要搜索的代码:

XElement root = XElement.Load(@"c:\b.txt", LoadOptions.PreserveWhitespace);
IEnumerable<XElement> address =
             from el in root.Elements("Address")
              select el;
int c = address.Count();

c 的值为 2,数据如下:

<?xml version="1.0" encoding="UTF-8"?>
<presence xmlns:a="urn:ietf:params:xml:ns:pidf"
  xmlns:dm="urn:ietf:params:xml:ns:pidf:data-model"
  xmlns:oma="urn:xml:prs:pidf:oma-pres"
  entity="sip:john@police.city.gov">
  <Address Type="Shipping">
    <Name>Ellen Adams</Name>
    <Street>123 Maple Street</Street>
    <City>Mill Valley</City>
    <State>CA</State>
    <Zip>10999</Zip>
    <Country>USA</Country>
  </Address>
  <Address Type="Billing">
    <Name>Tai Yee</Name>
    <Street>8 Oak Avenue</Street>
    <City>Old Town</City>
    <State>PA</State>
    <Zip>95819</Zip>
    <Country>USA</Country>
  </Address>
</presence>

但是,如果我通过将第二行更改为(xmlns 而不是 xmlns:a)来更改 XML:

 <presence xmlns="urn:ietf:params:xml:ns:pidf"

我得到的值为 0,这是不正确的。

有什么建议吗?

谢谢

4

2 回答 2

4

xmlns="urn:ietf:params:xml:ns:pidf"意味着,您为 xml 中没有指定任何命名空间的所有元素设置默认命名空间。

因此,您还应该将命名空间声明添加到您的 LINQ to XML 查询中,如下所示:

XElement root = XElement.Load(@"c:\b.txt", LoadOptions.PreserveWhitespace);

XNamespace xmlns = "urn:ietf:params:xml:ns:pidf";

IEnumerable<XElement> address = root.Elements(xmlns + "Address");

Console.WriteLine(address.Count()); //prints 2

或者您可以使用与命名空间无关的方法,无论指定什么默认命名空间,该方法都将起作用:

var address = root.Elements()
                  .Where(node => node.Name.LocalName == "Address");
//address will contain the same nodes, as in previous example

另请注意,在这种情况下,扩展方法语法要简洁得多。

于 2013-05-22T10:04:03.877 回答
4

通过设置 xmlns="urn:ietf:params:xml:ns:pidf" 您已经为所有元素设置了默认命名空间。因此,“地址”元素不再存在。现在称为“urn:ietf:params:xml:ns:pidf:Address”。

您需要做的是声明一个 XNamespace 并将其添加到元素名称中:

XNamespace defaultNamespace = "urn:ietf:params:xml:ns:pidf";
XElement root = XElement.Load(@"c:\b.txt", LoadOptions.PreserveWhitespace);
IEnumerable<XElement> address =
             from el in root.Elements(defaultNamespace + "Address")
              select el;
int c = address.Count();
于 2013-05-22T10:05:02.367 回答