Es gibt eine ähnliche Frage, aber es scheint, dass die Lösung in meinem Fall nicht funktioniert hat: Verrücktheit mit XDocument, XPath und Namespaces
Hier ist das XML, mit dem ich arbeite:
<?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>
Und unten ist der Code, von dem ich dachte, dass er funktionieren sollte, aber er hat nicht ...
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);
Hat jemand irgendwelche Ideen? Vielen Dank.
Antworten:
Wenn Sie über XDocument verfügen, ist die Verwendung von LINQ-to-XML einfacher:
Wenn Sie sicher sind, dass XPath die einzige Lösung ist, die Sie benötigen:
quelle
XPath 1.0, das von MS implementiert wird, hat nicht die Idee eines Standard-Namespace. Versuchen Sie Folgendes:
quelle
Sie können das Beispiel von Microsoft verwenden - für Sie ohne Namespace:
Sollte es tun
quelle