循环通过XML中的多个子节点

问题描述:

<Sections> 
    <Classes> 
     <Class>VI</Class> 
     <Class>VII</Class> 
    </Classes> 
    <Students> 
     <Student>abc</Student> 
     <Student>def</Student> 
    </Students>  
    </Sections> 

我必须通过类循环才能将'Class'变成一个字符串数组。我还必须循环“学生”以将'学生'放入一串字符串中。循环通过XML中的多个子节点

XDocument doc.Load("File.xml"); 
    string str1; 
    foreach(XElement mainLoop in doc.Descendants("Sections")) 
     { 
      foreach(XElement classLoop in mainLoop.Descendants("Classes")) 
       str1 = classLoop.Element("Class").Value +","; 
     //Also get Student value 
     } 

无法获取所有类。另外,我需要使用LINQ to XML来重写此而不使用,即使用XmlNodeList和XmlNodes。

XmlDocument doc1 = new XmlDocument(); 
doc1.Load("File.xml"); 
foreach(XmlNode mainLoop in doc.SelectNodes("Sections")) ?? 

不知道该怎么去做。

+0

这是功课? – 2011-06-09 16:16:29

+0

只是从家庭作业中删除家,就是这样。 ;) – user752709 2011-06-09 16:17:53

的XPath是直截了当的。要将结果导入数组,您可以使用LINQ或常规循环。

var classNodes = doc.SelectNodes("/Sections/Classes/Class"); 
// LINQ approach 
string[] classes = classNodes.Cast<XmlNode>() 
          .Select(n => n.InnerText) 
          .ToArray(); 

var studentNodes = doc.SelectNodes("/Sections/Students/Student"); 
// traditional approach 
string[] students = new string[studentNodes.Count]; 
for (int i = 0; i < studentNodes.Count; i++) 
{ 
    students[i] = studentNodes[i].InnerText; 
} 

不知道想改写它,但的XMLNodes为您的类和学生,你可以简单地说:

XDocument doc.Load("File.xml"); 
    foreach(XElement c in doc.Descendants("Class")) 
    { 
     // do something with c.Value; 
    } 

    foreach(XElement s in doc.Descendants("Student")) 
    { 
     // do something with s.Value; 
    } 
+0

谢谢,这就是我需要循环通过。 – user752709 2011-06-09 16:34:08

使用LINQ到XML:

XDocument doc = XDocument.Load("file.xml"); 
var classNodes = doc.Elements("Sections").Elements("Classes").Elements("Class"); 
StringBuilder result = new StringBuilder(); 
foreach(var c in classNodes) 
    result.Append(c.Value).Append(","); 

在XPath:

XmlDocument doc = new XmlDocument(); 
doc.Load("file.xml"); 
var classNodes = doc.SelectNodes("/Sections/Classes/Class/text()"); 
StringBuilder result = new StringBuilder(); 
foreach(XmlNode c in classNodes) 
    result.Append(c.Value).Append(",");