使用LINQ到XML返回子节点



使用以下XML

<?xml version="1.0"?>
<Message>
      <ArrayOfStock xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
            <Stock>
                  <StockID>9cddb639-25ee-4415-be07-3109e5ae9883</StockID>
                  <Description>Stock Item 0</Description>
            </Stock>
            <Stock>
                  <StockID>f89f02f9-b359-48c8-8d2f-3a950837f4fb</StockID>
                  <Description>Stock Item 1</Description>
            </Stock>
            <Stock>
                  <StockID>3338ec80-f59e-4979-a04c-f7d52e386bb7</StockID>
                  <Description>Stock Item 2</Description>
            </Stock>
      </ArrayOfStock>
</Message>

有人可以告诉我如何我将返回只是ArrayOfStock XML?

我用过

using (MemoryStream memStream = new MemoryStream(this.Message))
{
    XDocument doc = XDocument.Load(memStream);
    var message = from arrayOfStock in doc.Elements("Message")
                  select arrayOfStock;
}     

它似乎返回ArrayOfStock,但也包括消息节点本身

使用

var arrayOfStockNodes = from arrayOfStock 
                        in doc.Root.Elements("ArrayOfStock") 
                        select arrayOfStock;

因为你想有ArrayOfStock标记,你应该指定它…

我相信这个问题的答案可能对你有帮助。

如果可以有多个:

IEnumerable<XElement> arraysOfStock = doc.Root.Elements("ArrayOfStock");

如果只有一个:

XElement arrayOfStock = doc.Root.Element("ArrayOfStock");
doc.Descendants("ArrayOfStock").Concat(new[] { doc.Root });

try this

 var result = from c in XDocument.Load("PATH_OF_XML_FILE").Descendants("ArrayOfStock")
                          select c;

相关内容

  • 没有找到相关文章

最新更新