如何在XDocument中使用XPath?
有一个类似的问题,但是在我看来,该解决方案没有解决:XDocument,XPath和名称空间的怪异之处
这是我正在使用的XML:
<?xml version="1.0" encoding="utf-8"?><Report Id="ID1" Type="Demo Report" Created="2011-01-01T01:01:01+11:00" Culture="en" xmlns="http://demo.com/2011/demo-schema">
<ReportInfo>
<Name>Demo Report</Name>
<CreatedBy>Unit Test</CreatedBy>
</ReportInfo>
</Report>
下面是我认为应该可以正常运行的代码,但是没有成功…
XDocument xdoc = XDocument.Load(@"C:\SampleXML.xml");XmlNamespaceManager xnm = new XmlNamespaceManager(new NameTable());
xnm.AddNamespace(String.Empty, "http://demo.com/2011/demo-schema");
Console.WriteLine(xdoc.XPathSelectElement("/Report/ReportInfo/Name", xnm) == null);
有人有什么想法吗?谢谢。
回答:
如果您拥有XDocument,则使用LINQ-to-XML会更容易:
var document = XDocument.Load(fileName);var name = document.Descendants(XName.Get("Name", @"http://demo.com/2011/demo-schema")).First().Value;
如果确定XPath是唯一需要的解决方案,则:
using System.Xml.XPath;var document = XDocument.Load(fileName);
var namespaceManager = new XmlNamespaceManager(new NameTable());
namespaceManager.AddNamespace("empty", "http://demo.com/2011/demo-schema");
var name = document.XPathSelectElement("/empty:Report/empty:ReportInfo/empty:Name", namespaceManager).Value;
以上是 如何在XDocument中使用XPath? 的全部内容, 来源链接: utcz.com/qa/414856.html