当元素在其名称中有冒号时,如何使用LINQ查询XDocument?

我正在使用XDocument对象中的LINQ to XML。在下面的例子中如何查询结果元素?
<serv:header>
   <serv:response>
      <serv:result>SUCCESS</serv:result>
      <serv:gsbStatus>PRIMARY</serv:gsbStatus>
   </serv:response>
</serv:header>

当我使用这样的语句时,我得到异常’附加信息:’:’字符,十六进制值0x3A,不能包含在名称中。

XDocument doc = XDocument.Parse(xml);
string value = doc.Descendants("serv:header").First().Descendants("serv:response").First().Descendants("serv:result").First().Value;
你的XML中的serv是一个命名空间前缀。它必须与标识命名空间的URI相关联。在XML中寻找这样的属性:
xmlns:serv="..."

引号内的值将是命名空间。现在,在你的C#代码中,你使用该URI创建一个XNamespace对象:

private static readonly XNamespace serv = "...";

然后你可以在这样的查询中使用它:

string value = doc
    .Descendants(serv + "header").First()
    .Descendants(serv + "response").First()
    .Descendants(serv + "result").First()
    .Value;

顺便说一句,你应该考虑使用.Element()而不是.Descendants()。First()。

相关文章

php输出xml格式字符串
J2ME Mobile 3D入门教程系列文章之一
XML轻松学习手册
XML入门的常见问题(一)
XML入门的常见问题(三)
XML轻松学习手册(2)XML概念