连接XPath数组中的内部文本

时间:2015-09-10 02:25:39

标签: c# xpath linq-to-xml

我有一些看起来像这样的XML:

<root>
  <instructions type="array">
    <item type="string">Cannot do business directly with consumers</item>
    <item type="string">Cannot marry a martian</item>
  </instructions>
</root>

instructions变量看起来像这样:

var instructions = myXDocument.XPathSelectElements("/root/instructions").Nodes();

我试图连接所有item字符串,因此:

  “不能直接与消费者做生意,不能嫁给火星人”

我到目前为止的尝试是

instructions.Select(x => x.[[What do I put here?]]).Aggregate((i,j) => i + ", " + j)

但无法弄清楚如何从我的lambda表达式中的每个节点获取内部文本。 x.ToString()会产生"<item type="string">Cannot do business directly with consumers</item>"

3 个答案:

答案 0 :(得分:1)

使用相同的方法,您只需将Nodes()替换为Elements(),然后访问返回的Value的{​​{1}}属性即可获取内部文本:

XElements

答案 1 :(得分:0)

我知道这不是你正在寻找的lambda表达式,但这是获得结果输出的方法。

string result;
XElement root = XElement.Load(SomeXML);
root.Element("root").Elements("instructions").Elements("item").All<XElement>(xe =>
{
    result = result + xe.Attribute("type").Value),
    return true;
});

答案 2 :(得分:0)

试试这个

var xml = "<root><instructions type=\"array\"><item type=\"string\">Cannot do business directly with consumers</item><item type=\"string\">Cannot marry a martian</item></instructions></root>";
var document = XDocument.Parse(xml);
var result = string.Join(", ", document.Descendants("instructions").Elements("item").Select(x=>x.Value));

输出:

  

不能直接与消费者做生意,不能嫁给火星人