注意:使用 Windows Mobile 6.5 Compact Framework。
我有以下对象的集合。
public class RFileModel
{
public List<string> RequiredFilesForR = new List<string>();
public string Date { get; set; }
public string RouteId { get; set; }
}
var ListOfRFileModels = new List<RFileModel>();
相同的 RouteId
可能会出现在 RFileModel
的多个实例中,但具有不同的Date
。
我正在尝试识别重复项并仅选择一个,即最接近当前日期的一个。
到目前为止我有以下 LINQ:
var query = ListOfRFileModels.GroupBy(route => route.RouteId)
.OrderBy(newGroup => newGroup.Key)
.Select(newGroup => newGroup).ToList();
但我认为这不是我需要的,因为它仍然返回所有元素。我期待一个非唯一的 RouteId
列表,这样我就可以迭代每个非唯一的 id 并比较日期以查看要保留哪个。
如何使用 LINQ 或普通的 ole foreach
来完成此操作?
最佳答案
您的表达式对组进行排序,而不是对组元素进行排序。以下是修复方法:
DateTime currentDate = ...
var query = ListOfRFileModels
.GroupBy(route => route.RouteId)
.Select(g => g.OrderBy(fm => currentDate-fm.Date).First())
.ToList();
currentDate-fm.Date
表达式生成当前日期与 RFileModel
对象的日期之间的差异。差异最小的对象最终将位于有序序列的第一个位置。调用 First()
从组中选取它以产生最终结果。
关于c# - 查找重复的项目,然后选择日期与 currentDate 最接近的一项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33245517/