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.
1
Vea la otra respuesta a continuación, no funciona ya que la implementación de XPath 1.0 no puede hacer frente a un prefijo vacío
—
Paul Hatcher
Como otros dijeron aquí, no use un prefijo vacío al agregar un espacio de nombres al [XmlNamespaceManager]. Solo agrego este comentario en caso de que alguien quiera ver un pequeño ejemplo de código con un documento que tiene varios atributos [xmlns], con y sin sufijo. Vea aquí: stackoverflow.com/a/38272604/5838538
—
Jelgab