我在前面张贴了另一个关于如何改变与《国际公路货运公约》的XmlDocument的职位,但也许有可能与《路运危险货物协定》打交道。
我有一份XmlDocument,研究的是:
<DocumentElement>
<Customer>
<CustomerId>2315</CustomerId>
<VersionNumber>1</VersionNumber>
<GUID>2E05DE20-02A0-425D-944D-65E5E744FF8A</GUID>
</Customer>
<Customer>
<CustomerId>2316</CustomerId>
<VersionNumber>2</VersionNumber>
<GUID>2E05DE20-02A0-425D-944D-65E5E744FF8A</GUID>
</Customer>
<Customer>
<CustomerId>2317</CustomerId>
<VersionNumber>1</VersionNumber>
<GUID>9995DE20-02A0-425D-944D-65E5E744FF8A</GUID>
</Customer>
</DocumentElement>
有了LINQ,我能否为每个独一无二的GUID提取一个客户要素,并使客户获得最高数字?
一、即新文件/文件将考虑:
<DocumentElement>
<Customer>
<CustomerId>2316</CustomerId>
<VersionNumber>2</VersionNumber>
<GUID>2E05DE20-02A0-425D-944D-65E5E744FF8A</GUID>
</Customer>
<Customer>
<CustomerId>2317</CustomerId>
<VersionNumber>1</VersionNumber>
<GUID>9995DE20-02A0-425D-944D-65E5E744FF8A</GUID>
</Customer>
</DocumentElement>
提前感谢。
最新情况:
因此,我应该做(如果我正确理解你的话):
XDocument xdoc = new XDocument();
using (StringWriter sw = new StringWriter())
{
// Converts the datatable to XML
dt.WriteXml(sw);
xdoc = XDocument.Parse(sw.ToString());
}
var query = xdoc.Root
.Elements("Customer")
.GroupBy(x => x.Element("GUID").Value)
.Select(g => g.OrderByNumberDescending(x =>(int)x.Element("VersionNumber"))
.First());
不过,我还是把错误带上了B组,或者我在这里做一些其他错误?