簡體   English   中英

Linq 最小日期 最大日期 model 查詢

[英]Linq min date max date model querying

我無法了解如何從字典集合中獲取最小日期和最大日期。

我的 model 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來“展平”字典值,然后使用MinMax方法:

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給出正確的結果。


如果您想獲取每個字典Key的 Min/Max,則可以投影為匿名類型:

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

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM