根据XElement的名称对XDocument进行排序

本文关键字:XDocument 排序 XElement 根据 | 更新日期: 2023-09-27 18:01:33

我有一个XML文件,如下所示:

 <file name="picture1.jpg"/>
 <file name="file1.txt"/>
 <folder name="subfolder">
      <file name="picture2.jpg"/>
      <file name="file2.txt"/>
      <folder name="anotherfolder">
           <file name="file3.txt"/>
      </folder>
 </folder>
 <folder name="anotherfolder">
 </folder>

它需要这样排序:

<folder name="anotherfolder">
 </folder>
 <file name="file1.txt"/>
 <file name="picture1.jpg"/>
 <folder name="subfolder">
      <folder name="anotherfolder">
           <file name="file3.txt"/>
      </folder>
      <file name="file2.txt"/>
      <file name="picture2.jpg"/>
 </folder>

我必须排序的代码是:

public static XDocument Sort(XDocument file)
    {
        return new XDocument(Sort(file.Root));
    }
    private static XElement Sort(XElement element)
    {
        XElement newElement = new XElement(element.Name,
            from child in element.Elements()
            orderby child.Name.ToString()
            select Sort(child));
        if (element.HasAttributes)
        {
            foreach (XAttribute attrib in element.Attributes())
            {
                newElement.SetAttributeValue(attrib.Name, attrib.Value);
            }
        }
        return newElement;
    }

它完成了任务。。。但只是部分。它根据与FOLDER不同的名称属性对FILE进行排序。我希望将它们一起考虑用于排序的xml。该怎么办?

根据XElement的名称对XDocument进行排序

实际上,此代码不按名称属性对子元素进行排序;它按元素名称排序:

orderby child.Name.ToString()

您需要做的是获取"name"属性的值(区分大小写!(。这在child.Attribute("name")中是可能的,但您需要获得它的.Value,同时注意null属性;代码在内联中编写会有点尴尬。

就我个人而言,我发现这个带有child.Attributes(返回集合(的版本更方便:

orderby child.Attributes("name").Select(a => a.Value).FirstOrDefault()
.OrderBy(e=>e.Attribute("name").Value)

如果您想排序,或者只在节点的IEnumerable上使用此方法对它们进行排序,请在任何级别递归执行此操作