4

在 C# 中,我试图对XDocumentusing进行排序OrderByDescending。目标是读取包含日期/时间戳的子节点之一并重新排序父节点。

我从保存的文件中加载 XML,如下所示:

XDocument Doc = new XDocument();
Doc= XDocument.Load(filename);

这是我的 XML 的示例:

<KS>
  <Team>   
    <TeamName>Knights</TeamName>
    <TeamColor>blue</TeamColor>
    <LastAccessed>5/9/2013 2:34:22 PM</LastAccessed>
  </Team>
  <Team>
    <TeamName>Rangers</TeamName>
    <TeamColor>red</TeamColor>
    <LastAccessed>5/9/2013 3:49:06 PM</LastAccessed>
  </Team>
  <Team>
    <TeamName>Eagles</TeamName>
    <TeamColor>green</TeamColor>    
    <LastAccessed>5/9/2013 3:50:18 PM</LastAccessed>
  </Team>
</KS>

我想<Team>根据子元素重新排序降序<LastAccessed>

我尝试了以下方法,但没有任何运气:

var results = Doc.Root.Descendants("Team").OrderByDescending(p => p.Element("LastAccessed"));

XDocument node = new XDocument(Doc.Descendants("KS").OrderByDescending(x => x.Element("Team").Element("LastAccessed").Value.Trim()));

有什么建议可以根据存储在子节点中的值对 XML 父节点进行排序吗?

4

2 回答 2

6

你应该得到一个错误,上面写着:

至少一个对象必须实现 IComparable。

请始终在您的问题中包含这些错误。

您需要提供Team支持IComparable接口的元素的子元素。您需要获得价值,而不是XElement.Elements您带来的价值。

将您的结果行更改为以下内容,它将起作用。

var results = Doc.Descendants("Team").OrderByDescending(p => DateTime.Parse(p.Element("LastAccessed").Value));
于 2013-05-14T20:26:22.953 回答
0
var results = Doc.Root.Descendants("Team").OrderByDescending(p =>    (DateTime)p.Element("LastAccessed"));
于 2013-05-14T20:27:48.640 回答