Есть аналогичный вопрос, но, похоже, в моем случае решение не сработало: странность с XDocument, XPath и пространствами имен
Вот XML, с которым я работаю:
<?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>
И ниже приведен код, который, как я думал, должен работать, но это не так ...
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);
У кого-нибудь есть идеи? Спасибо.
Ответы:
Если у вас есть XDocument, проще использовать LINQ-to-XML:
Если вы уверены, что XPath - единственное решение, которое вам нужно:
источник
XPath 1.0, который реализует MS, не имеет представления о пространстве имен по умолчанию. Так что попробуйте это:
источник
вы можете использовать пример от Microsoft - для вас без пространства имен:
должен сделать это
источник