Linq最小日期最大日期模型查询
Linq min date max date model querying
我无法找到如何从字典集合中获取最小日期和最大日期。
我的模型 class 看起来像这样:
Dictionary<string, IList<ErrorModel>> errorList
public class ErrorModel
{
public string Date { get; set; }
public int Total { get; set; }
public string Description { get; set; }
}
我想做的是获取集合的最小日期和最大日期。
希望有人能帮帮我
您可以使用 Linq 的 Enumerable.SelectMany
to "flatten" the dictionary values, then use Min
and Max
方法:
var minDate = errorList.SelectMany(s => s.Value).Min(v => v.Date);
var maxDate = errorList.SelectMany(s => s.Value).Max(v => v.Date);
但是,你的Date
属性定义为字符串,你可能得不到你期望的结果。将定义更新为 DateTime
将使用 Min/Max
.
给出正确的结果
如果你想获得每个字典 Min/Max Key
,你可以投影到匿名类型:
var perKeyMinMax = errorList.Select(d => new { d.Key,
Min = d.Value.Min(v => v.Date),
Max = d.Value.Max(v => v.Date)
});
foreach (var item in perKeyMinMax)
{
Console.WriteLine($"Key: {item.Key}, Min: {item.Min}, Max: {item.Max}");
}
我无法找到如何从字典集合中获取最小日期和最大日期。
我的模型 class 看起来像这样:
Dictionary<string, IList<ErrorModel>> errorList
public class ErrorModel
{
public string Date { get; set; }
public int Total { get; set; }
public string Description { get; set; }
}
我想做的是获取集合的最小日期和最大日期。
希望有人能帮帮我
您可以使用 Linq 的 Enumerable.SelectMany
to "flatten" the dictionary values, then use Min
and Max
方法:
var minDate = errorList.SelectMany(s => s.Value).Min(v => v.Date);
var maxDate = errorList.SelectMany(s => s.Value).Max(v => v.Date);
但是,你的Date
属性定义为字符串,你可能得不到你期望的结果。将定义更新为 DateTime
将使用 Min/Max
.
如果你想获得每个字典 Min/Max Key
,你可以投影到匿名类型:
var perKeyMinMax = errorList.Select(d => new { d.Key,
Min = d.Value.Min(v => v.Date),
Max = d.Value.Max(v => v.Date)
});
foreach (var item in perKeyMinMax)
{
Console.WriteLine($"Key: {item.Key}, Min: {item.Min}, Max: {item.Max}");
}