我有像这样的XML
<Root>
<NodeA>
<NodeA1>
<NodeA11>
<SameNameNode>
<SameNameNodeChild1>Value 1</SameNameNodeChild1>
<SameNameNodeChild2>Value 2</SameNameNodeChild2>
</SameNameNode>
</NodeA11>
</NodeA1>
</NodeA>
<NodeB>
<SameNameNode>
<SameNameNodeChild1>Value 3</SameNameNodeChild1>
<SameNameNodeChild2>Value 4</SameNameNodeChild2>
</SameNameNode>
</NodeB>
<NodeC>
<NodeC1>
<SameNameNode>
<SameNameNodeChild1>Value 5</SameNameNodeChild1>
<SameNameNodeChild2>Value 6</SameNameNodeChild2>
</SameNameNode>
</NodeC1>
</NodeC>
</Root>
正如您所看到的,“SameNameNode”及其子节点出现在不同嵌套级别的几个位置,但名称相同。如何仅使用LINQ to XML获取“值1”和“值2”的元素值。谢谢。
答案 0 :(得分:1)
以下是一些将获取值的完整示例代码:
public static void Main()
{
var xdoc = XDocument.Parse(@"
<Root>
<NodeA>
<NodeA1>
<NodeA11>
<SameNameNode>
<SameNameNodeChild1>Value 1</SameNameNodeChild1>
<SameNameNodeChild2>Value 2</SameNameNodeChild2>
</SameNameNode>
</NodeA11>
</NodeA1>
</NodeA>
<NodeB>
<SameNameNode>
<SameNameNodeChild1>Value 3</SameNameNodeChild1>
<SameNameNodeChild2>Value 4</SameNameNodeChild2>
</SameNameNode>
</NodeB>
<NodeC>
<NodeC1>
<SameNameNode>
<SameNameNodeChild1>Value 5</SameNameNodeChild1>
<SameNameNodeChild2>Value 6</SameNameNodeChild2>
</SameNameNode>
</NodeC1>
</NodeC>
</Root>");
var results = xdoc.Root
.Elements("NodeA")
.Elements("NodeA1")
.Elements("NodeA11")
.Elements("SameNameNode")
.Descendants()
.Select(e => new { ElementName = e.Name, ElementValue = e.Value });
foreach (var result in results)
Console.WriteLine("Name = {0}, Value = {1}", result.ElementName, result.ElementValue);
}
这将输出:
Name = SameNameNodeChild1, Value = Value 1
Name = SameNameNodeChild2, Value = Value 2
您可能需要调整查询 - 我假设您想要所有“SameNameNode”的后代,但您可能只想过滤某些子元素。
@Mun,为了回答有关LINQ查询语法的问题,您可以使用此代码执行相同的操作。这两段代码是等价的:
var results = from nodeAElem in xdoc.Root.Elements("NodeA")
from nodeA1Elem in nodeAElem.Elements("NodeA1")
from nodeA11Elem in nodeA1Elem.Elements("NodeA11")
from sameNameNodeElem in nodeA11Elem.Elements("SameNameNode").Descendants()
select new { ElementName = sameNameNodeElem.Name, ElementValue = sameNameNodeElem.Value };