使用XML获取具有相同名称的所有元素的内容?

时间:2012-10-11 14:51:03

标签: c# .net xml xml-parsing linq-to-xml

我正在尝试解析程序中的一些XML,但我似乎无法找到最佳方法。

XML有一个名为" container"的元素。该元素有多个后代,称为" text"。我想做的是取出" text"中的值。元素,按顺序,并将它们保存在字符串中。

所以XML看起来像:

<containers>
   <container>
      <elt3243> </elt3243>
      <elt1122></elt1122>
      <elt><text> Put me in a string please </text> </elt>
      <elt2211></elt2211>
   </container>
   <container>
      <elt3243><text>I would also like to be in the string</text></elt3243>
      <elt1122></elt1122>
      <elt> </elt>
      <elt2211></elt2211>
   </container>
</containers>

我想要的结果:

String result = "Put me in a string please \n I would also like to be in the string";

这样做的最佳方式是什么?

5 个答案:

答案 0 :(得分:2)

XDocument doc = XDocument.Load(file.FullName);
var strings = doc.Descendants("container").SelectMany(x => x.Descendants("text")).ToList();
return strings.Join(" \n ");

答案 1 :(得分:1)

试试这个

XDocument xDocument = new XDocument();
//load xml
StringBuilder sb = new StringBuilder();

foreach(var text in xDocument.Descendants("text") )
{
sb.append(text.value)
}

答案 2 :(得分:1)

这是一个Win32控制台示例,应该演示您可以做什么:

var doc = XDocument.Parse(
    "<containers>" + 
        "<container>"+
          "<elt3243> </elt3243>"+
          "<elt1122></elt1122>"+
          "<elt><text> Put me in a string please </text> </elt>"+
          "<elt2211></elt2211>"+
       "</container>"+
       "<container>"+
          "<elt3243><text>I would also like to be in the string</text></elt3243>"+
          "<elt1122></elt1122>"+
          "<elt> </elt>"+
          "<elt2211></elt2211>"+
       "</container>"+
    "</containers>", LoadOptions.None);

var text = doc.Descendants("text").Select(x => x.Value);
Console.WriteLine(string.Join(" \n ", text));
Console.ReadKey(false);

请注意,您并不需要将其投影到数组或列表中,正如之前的一些答案所示。 string.Join只需要一个分隔符和一个对象数组;数组的IEnumerable<string>由运行时隐式处理。要测试它,请创建一个新的C#Console应用程序,并将其放入Main()。应该按原样工作......

答案 3 :(得分:0)

您可以使用XPath,有关MSDN的更多信息,请参阅此处。

所以,像这样:

XPathDocument document = new XPathDocument(<Source of your XML >);
XPathNavigator navigator = document.CreateNavigator();

XPathNodeIterator nodes = navigator.Select("//text");

string result = "";
while (nodes.MoveNext())
{
    result += nodes.Current.Value + "\n";
}

答案 4 :(得分:0)

XDocument是你的朋友......

var doc = XDocument.Load(...filename...);
var strings = doc.Descendants("text").Select(x => x.Value).ToArray();
var result = string.Join("\r\n", strings);

使用ForEach扩展方法可能有更简单的方法......