我有一个 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,只能访问项目列表。
答案 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;
您可以尝试XPathNavigator
和XPathExpression
。
//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)
我以一种非常不优雅的方式解决了这个问题:
答案 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));