循环通过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")) ??
不知道该怎么去做。
答
的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(",");
这是功课? – 2011-06-09 16:16:29
只是从家庭作业中删除家,就是这样。 ;) – user752709 2011-06-09 16:17:53