C# Linq仅选择最新的副本
我已经搜索过帖子,但这让我感到困扰: 我正在尝试从XML中删除重复项并仅保留最新的: XML结构是:C# Linq仅选择最新的副本,c#,xml,linq,C#,Xml,Linq,我已经搜索过帖子,但这让我感到困扰: 我正在尝试从XML中删除重复项并仅保留最新的: XML结构是: <?xml version="1.0" encoding="utf-8"?> <scanneditems> <item> <itemnumber>5701075006328</itemnumber> <description>Item 1</description> <times
<?xml version="1.0" encoding="utf-8"?>
<scanneditems>
<item>
<itemnumber>5701075006328</itemnumber>
<description>Item 1</description>
<timestamp>16-06-2017 10:40:39</timestamp>
</item>
<item>
<itemnumber>5701075006328</itemnumber>
<description>Item 1 duplicate</description>
<timestamp>08-06-2017 14:25:51</timestamp>
</item>
</scanneditems>
问题:如何将每个副本的结果限制为最新?如果我理解正确,您需要从每个副本中获取最新的项目。
因此,在分组项目中使用
OrderBy..
XDocument xDoc = XDocument.Load(@"C:\\fixthis.xml");
var items =
xDoc.Element("scanneditems")
.Elements("item")
.GroupBy(c => c.Element("itemnumber").Value)
.Select(g => g.OrderByDescending(c => c.Element("timestamp").Value).First());
var doc = new XDocument(new XElement("scanneditems", items));
doc.Save("C:\\fixedfile.xml");
我认为您需要对其进行正确排序,默认情况下,此代码将按字母顺序对时间戳进行排序。然后打电话给Distinct。非常感谢!正是我想要的。
XDocument xDoc = XDocument.Load(@"C:\\fixthis.xml");
var items =
xDoc.Element("scanneditems")
.Elements("item")
.GroupBy(c => c.Element("itemnumber").Value)
.Select(g => g.OrderByDescending(c => c.Element("timestamp").Value).First());
var doc = new XDocument(new XElement("scanneditems", items));
doc.Save("C:\\fixedfile.xml");