使用LINQ的XDocument一个XML文件中读取最后n个元素 [英] Read last n elements of an XML file with Linq XDocument
本文介绍了使用LINQ的XDocument一个XML文件中读取最后n个元素的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我使用的是后续code读取XML文件:
I am using the follow Code to read an XML file:
XDocument doc = XDocument.Load(xmlPath);
foreach (var node in doc.Descendants("LogInfo"))
{
ListViewItem item = new ListViewItem(new string[]
{
node.Element("MailBox").Value,
node.Element("LastRun").Value,
});
listViewHome.Items.Add(item);
}
我怎样才能改变这种code接收刚刚过去的N从XML文件中元素的个数?
先谢谢了。
How can I change this Code to receive just the last "n" number of elements from that XML file? Thanks in advance.
推荐答案
您可以这样做:
var nodes = doc.Descendants("LogInfo");
foreach (var node in nodes.Skip(Items.Count() - n))
{
...
}
或者这样:
var nodes = doc.Descendants("LogInfo");
foreach (var node in nodes.Reverse().Take(n).Reverse())
{
...
}
如果你喜欢冒险的感觉,你也可以写自己的扩展这应该是比任何这些更有效的方法的。这里是我的快速和肮脏的解决方案:
If you're feeling adventurous, you could also write your own extension method which should be more efficient than either of these. Here's my quick and dirty solution:
public static IEnumerable<T> TakeFromEnd<T>(this IEnumerable<T> items, int n)
{
var arry = new T[n];
int i = 0;
foreach(var x in items)
{
arry[i++ % n] = x;
}
if (i < n)
{
n = i;
i = 0;
}
for (int j = 0; j < n; j++)
{
yield return arry[(i + j) % n];
}
}
var nodes = doc.Descendants("LogInfo");
foreach (var node in nodes.TakeFromEnd(n))
{
...
}
这篇关于使用LINQ的XDocument一个XML文件中读取最后n个元素的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文