1

我有一个这样的 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。应该做什么?

4

2 回答 2

2

实际上,这段代码并没有按 name属性对子元素进行排序;它按元素名称排序:

orderby child.Name.ToString()

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

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

orderby child.Attributes("name").Select(a => a.Value).FirstOrDefault()
于 2013-02-27T10:00:14.057 回答
0
.OrderBy(e=>e.Attribute("name").Value)

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

于 2013-02-27T09:44:55.563 回答