Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/xml/15.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# Linq仅选择最新的副本_C#_Xml_Linq - Fatal编程技术网

C# Linq仅选择最新的副本

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中删除重复项并仅保留最新的:

XML结构是:

<?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");