如何在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

回到顶部