cómo usar XPath con XDocument?

Hay una pregunta similar, pero parece que la solución no funcionó en mi caso: rarezas con XDocument, XPath y espacios de nombres

Aquí está el XML con el que estoy trabajando:

   Demo Report Unit Test   

Y debajo está el código que pensé que debería estar funcionando, pero no …

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

¿Alguien tiene alguna idea? Gracias.

Si tiene XDocument, es más fácil usar LINQ-to-XML:

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

Si está seguro de que XPath es la única solución que necesita:

 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, que es lo que MS implementa, no tiene la idea de un espacio de nombres predeterminado. Entonces intente esto:

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