根据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。该怎么办?
实际上,此代码不按名称属性对子元素进行排序;它按元素名称排序:
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
上使用此方法对它们进行排序,请在任何级别递归执行此操作