gpt4 book ai didi

c# - 使用Linq XDocument读取XML文件的最后n个元素

转载 作者:太空宇宙 更新时间:2023-11-03 17:41:57 24 4
gpt4 key购买 nike

我正在使用以下代码读取XML文件:

    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);
}


如何更改此代码以仅接收该XML文件中最后“ n”个元素?
提前致谢。

最佳答案

您可以这样做:

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())
{
...
}


如果您喜欢冒险,还可以编写自己的 extension method,这应该比这两个方法都要有效。这是我的快速而肮脏的解决方案:

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))
{
...
}

关于c# - 使用Linq XDocument读取XML文件的最后n个元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17554175/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com