循环遍历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文档并在c#变量中分配数据

如果您提供的示例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);                    
          }
       }                      
    }