c# .net xml xpath linq-to-xml

c# - cómo usar XPath con XDocument?



.net xml (2)

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:

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

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