根据属性订购XmlNodeList

时间:2011-12-23 08:48:02

标签: c# xml

我有一个 XmlNodeList ,它包含来自以下XML示例的根目录的数据包(item)。我想根据节点的键属性值对XmlNodeList进行排序。 排序必须非常高效,每毫秒计算一次。

你有什么想法吗?

<root>
    <item key="1000000020">
        Content 20
    </item>
    <item key="1000000001">
        Content 1
    </item>
    ...
    <item key="1043245231">
        Content n
    </item>
</root>

编辑: 我已经从项目构造了一个XmlNodeList。我不再能够访问XmlDocument,只能访问项目列表。

3 个答案:

答案 0 :(得分:2)

您应该尝试使用Linq to XML。

 XDocument doc = XDocument.Load(file);

   var nodeList = from ele in doc.Descendants("item")
                   orderby int.Parse(ele.Attribute("key").Value)
                   select ele;

您可以尝试XPathNavigatorXPathExpression

 //I presume that variable xNodeList contains XmlNodeList.
  XPathNavigator nav=xNodeList.Item(0).OwnerDocument.CreateNavigator();
  XPathExpression exp = nav.Compile("root/item");


  exp.AddSort("@key", XmlSortOrder.Ascending, XmlCaseOrder.None, "", XmlDataType.Number );

  foreach (XPathNavigator t in nav.Select(exp))
  {
    Console.WriteLine(t.OuterXml );
   }

答案 1 :(得分:0)

我以一种非常不优雅的方式解决了这个问题:

  • 我迭代了我的 XmlNodeList
  • 在迭代期间,我提取了时间戳
  • 提取时间戳后,我将timestamp-XmlElement添加到 SortedDictionary
  • 将SortedDictionary转换为列表( sortedKeys = sortedByDateDisctionary.Keys.ToList();
  • 如果节点需要排序降序,那么 sortedKeys.Reverse();
  • 然后可以通过排序键访问节点

答案 2 :(得分:0)

注意:xml变量是字符串值

XmlDocument doc = new XmlDocument();
doc.LoadXml(xml);

IEnumerable<XmlNode> rows = doc.SelectNodes("report/table/row").Cast<XmlNode>().OrderByDescending(r => Convert.ToDecimal(r.Attributes["conversions"].Value));