come usare XPath con XDocument?

C’è una domanda simile, ma sembra che la soluzione non abbia funzionato nel mio caso: stranezza con XDocument, XPath e namespace

Ecco l’XML con cui sto lavorando:

   Demo Report Unit Test   

E sotto c’è il codice che pensavo avrebbe dovuto funzionare, ma non …

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

Qualcuno ha qualche idea? Grazie.

Se hai XDocument, è più facile usare LINQ-to-XML:

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

Se sei sicuro che XPath è l’unica soluzione di cui hai bisogno:

 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; 

XPath 1.0, che è ciò che implementa MS, non ha l’idea di uno spazio dei nomi predefinito. Quindi prova questo:

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