web-dev-qa-db-fra.com

comment utiliser XPath avec XDocument?

Il y a une question similaire, mais il semble que la solution n'ait pas fonctionné dans mon cas: Bizarre avec XDocument, XPath et les espaces de noms

Voici le XML avec lequel je travaille:

<?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>

Et ci-dessous est le code que je pensais qu'il devrait fonctionner mais il n'a pas ...

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);

Quelqu'un a-t-il une idée? Merci.

107
jojo

Si vous avez XDocument, il est plus facile d'utiliser LINQ-to-XML:

var document = XDocument.Load(fileName);
var name = document.Descendants(XName.Get("Name", @"http://demo.com/2011/demo-schema")).First().Value;

Si vous êtes sûr que XPath est la seule solution dont vous avez besoin:

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;
153
Alex Aza

XPath 1.0, qui est ce que MS implémente, n’a pas l’idée d’un espace de noms par défaut. Alors essayez ceci:

XDocument xdoc = XDocument.Load(@"C:\SampleXML.xml");
XmlNamespaceManager xnm = new XmlNamespaceManager(new NameTable()); 
xnm.AddNamespace("x", "http://demo.com/2011/demo-schema");
Console.WriteLine(xdoc.XPathSelectElement("/x:Report/x:ReportInfo/x:Name", xnm) == null);
6

vous pouvez utiliser l'exemple de Microsoft - pour vous sans espace de nom:

using System.Xml.Linq;
using System.Xml.XPath;
var e = xdoc.XPathSelectElement("./Report/ReportInfo/Name");     

devrait le faire

3
Bernhard