2011-12-04 163 views
0

請在下面找到xml數據。考慮到我知道父節點具有url =「#」,title =「item 1」和key =「Item1」,我希望使用LINQ查詢獲得具有鍵「Sub1」和「Sub2」的節點。LINQ XML獲取父節點的子節點

<root> 
<node title="Partner" url="" description="99" roles="GuidIdHere"></node> 
<node title="Test" url="" description="51" roles="8b0c0c4f" key="sample"> 
    <node url="#" title="item 1" description="" key="Item1"> 
     <node url="#" title="Sub 1" description="" key="Sub1" /> 
     <node url="#" title="Sub 2" description="" key="Sub2" /> 
    </node> 
    <node url="#" title="item 2" description="" key="Item2" /> 
    <node url="#" title="item 3" description="" key="Item3" /> 
</node> 
</root> 

謝謝!

回答

0
var result = from x in doc.Root.Descendents("node") 
      where (string)x.Attribute("url") == "#" 
       && (string)x.Attribute("title") == "item 1" 
       && (string)x.Attribute("key") == "Item1" 
      from y in x.Elements("node") 
      where (string)x.Attribute("key") == "Sub1" 
       || (string)x.Attribute("key") == "Sub2" 
      select y; 
+0

我只是不得不將doc.Root.Descendants更改爲doc.Descendants,但除此之外這是完美的!謝謝! – Ronald