循环遍历XML文档并在c#变量中分配数据
本文关键字:变量 分配 数据 遍历 XML 文档 循环 | 更新日期: 2023-09-27 18:18:53
我有一个XML文件,它有几个像这样的标签:
<sitecollection name="">
<site name="">
<maingroup name="">
<group name=""> </group>
</maingroup>
</site>
<sitecollection>
这个想法是遍历XML文档中的所有sitecollection
及其子元素,并将信息保存在变量中。我遇到的问题是保存子元素及其属性。
到目前为止,我有以下代码:
class xmlreader
{
public static void Main()
{
XDocument xdoc = XDocument.Load("xmldocument.xml");
var result = new System.Text.StringBuilder();
var lv1s = from lv1 in xdoc.Descendants("sitecollection")
select new
{
siecollection = lv1.Attribute("name").Value,
maingroup = lv1.Descendants("group")
};
foreach (var lv1 in lv1s)
{
result.AppendLine(lv1.siecollection);
foreach (var lv2 in lv1.maingroup)
result.AppendLine(" " + lv2.Attribute("name").Value);
}
}
}
如果您提供的示例XML是准确的,那么问题很可能是您没有sitecollection的结束标记。
我用稍微不同的XML输入(关闭sitecollection标签,并向名称属性添加一些值,以便在结果StringBuilder中收集一些东西)尝试了您的代码,如下所示:
XDocument xdoc = XDocument.Parse(@"<sitecollection name=""collectionName"">
<site name=""sitename"">
<maingroup name=""maingroupname"">
<group name=""groupname""> </group>
</maingroup>
</site>
</sitecollection>
");
和result.ToString()产生:"collectionName'r'n groupname'r'n"
随你便:
XmlReader reader = XmlReader.Create(@"C:'file.xml", null);
StringBuilder result = new StringBuilder();
while (reader.Read())
{
if( reader.NodeType == XmlNodeType.Element)
{
if (reader.HasAttributes)
{
result.AppendLine(reader.LocalName);
reader.MoveToFirstAttribute();
result.AppendLine(" " + reader.Value);
}
}
}