0

私はあまり見ずにかなりの数の異なる方法を試しました。誰かが助けてくれることを願っています:-)

XML:

<?xml version="1.0" encoding="UTF-8"?>
<ListOrdersResponse xmlns="https://services.com/Orders/2013-09-01">
   <ListOrdersResult>
      <Orders>
         <Order>
            <Id>1</Id>
         </Order>
         <Order>
            <Id>2</Id>
         </Order>
      </Orders>
   </ListOrdersResult>
</ListOrdersResponse>

試した:

var o =xmlDocument.SelectNodes("/ListOrdersResponse/ListOrdersResult/Orders/Order");
var o = xmlDocument.SelectNodes("/ListOrdersResponse/ListOrdersResult/Orders");
var o = xmlDocument.SelectNodes("//Orders");
var o = xmlDocument.SelectNodes("//Order");
var o = xmlDocument.SelectNodes("//Orders/Order");

var root = xmlDocument.DocumentElement;
var nsmgr = new XmlNamespaceManager(xmlDocument.NameTable);
nsmgr.AddNamespace("bk", "https://services.com/Orders/2013-09-01");
var orders = root.SelectNodes("descendant::bk:Orders/Order", nsmgr);

var root = xmlDocument.DocumentElement;
var nsmgr = new XmlNamespaceManager(xmlDocument.NameTable);
nsmgr.AddNamespace("bk", "https://services.com/Orders/2013-09-01");
var orders = root.SelectNodes("descendant::bk:Orders", nsmgr);

0 レコードを返すだけです。:-(

私は何を間違っていますか?

4

2 に答える 2

2

Linq2Xml を使用するのはどうですか? 使いやすいと思います。

XNamespace ns = "https://services.com/Orders/2013-09-01";
var orders = XDocument.Load(filename)
            .Descendants(ns + "Order")
            .Select(x => (int)x.Element(ns + "Id"))
            .ToList();

PS: XML では大文字と小文字が区別されます。問題のサンプルを確認してください。など<Order>_</order>

于 2015-07-31T08:33:53.660 に答える
1

var nsmgr = new XmlNamespaceManager(xmlDocument.NameTable);
nsmgr.AddNamespace("bk", "https://services.com/Orders/2013-09-01");

一部は正しいですが、プレフィックスを使用してbk、XPath 式のすべての要素名を修飾する必要があります。

XmlNodeList orders = xmlDocument.SelectNodes("//bk:Orders/bk:Order", nsmgr);
foreach (XmlElement order in orders) {
  Console.WriteLine(order.SelectSingleNode("bk:Id", nsmgr).InnerText);
}
于 2015-07-31T08:34:33.140 に答える