我试图在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
是 namespace 前缀。它必须与标识 namespace 的URI关联。在您的XML中寻找这样的属性:
xmlns:serv="..."
引号内的值将是 namespace 。现在,在您的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()
。
关于linq - 当元素名称中带有冒号时,如何使用LINQ查询XDocument?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1640108/