Hay una pregunta similar, pero parece que la solución no funcionó en mi caso: rareza con XDocument, XPath y los 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 a continuación está el código que pensé que debería estar funcionando pero no lo hizo ...
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.
Respuestas:
Si tiene XDocument, es más fácil usar LINQ-to-XML:
Si está seguro de que XPath es la única solución que necesita:
fuente
XPath 1.0, que es lo que implementa MS, no tiene la idea de un espacio de nombres predeterminado. Así que prueba esto:
fuente
puede usar el ejemplo de Microsoft , para usted sin espacio de nombres:
Deberías hacerlo
fuente