3 回答

TA貢獻1856條經驗 獲得超5個贊
問題是您將時間存儲為字符串和視圖模型中的列表。取決于您要完成的任務:即查找具有最新時間的資產跟蹤器:
model = model.AssetTrackers .OrderByDescending(x => x.time .Select(t=>DateTime.Parse(t)).OrderByDescending(t=>t).First()) .FirstOrDefault();
問題是您指示 Linq 將 DateTime.Parse 應用于一個List<string>
而不是列表中的每個單獨的字符串。
我建議將日期時間存儲為 DateTime 而不是字符串,或者至少將它們存儲在 ISO-8601 (YYYY-DD-MMTHH:mm:ss(Z)) 中,因為這可以進行比較和排序。
此外,如果您在這些資產跟蹤器和時間之間存在一對多的關系,那么我建議您將實體中的關系與 DateTimes 進行映射。如果數據庫正在存儲 DateTime,請避免轉換為字符串,即使您想在視圖模型中格式化日期。讓視圖模型將格式化的日期作為屬性公開,但允許代碼使用 DateTime,因為您可以準確地對其進行排序和比較,而無需 DateTime.Parse 的額外成本。

TA貢獻2039條經驗 獲得超8個贊
首先,我不能強調這一點,將日期存儲為字符串不是一個好主意。直接使用 DateTimes 即可。
您的AssetTracker對象有一個名為 的屬性time。該屬性是一個字符串列表。DateTime.Parse無法解析列表 - 它可以解析字符串。這就是您收到錯誤消息的原因。
從你的問題中你想做什么并不完全清楚。
您想按AssetTracker他們擁有的最高時間戳排序列表嗎?
var trackersByHighestTimeDesc =
model.AssetTrackers
.OrderByDescending(x => x.time.Select(DateTime.Parse).Max());
您是否要對每個時間戳列表進行排序,但保持資產跟蹤器的順序不變?
foreach(var at in model.AssetTrackers) {
at.time = at.time.OrderByDescending(DateTime.Parse);
}

TA貢獻1934條經驗 獲得超2個贊
time
是(并且不能是,這就是您收到錯誤的原因)的List<string>
屬性。您想如何根據每個項目的時間屬性進行排序?換句話說,您想如何將一個時間列表與另一個時間列表進行比較以確定排序順序?AssetTracker
DateTime
Parse
List<string>
List<AssetTracker>
由于您正在比較 a 屬性上的對象List<string>
,因此您需要某種方法來確定該屬性值的基線。我想到了兩種方法:Min
和Max
:
從列表中獲取每個對象的最大時間并將其用作比較:
model.AssetTrackers = model.AssetTrackers .OrderByDescending(x => x.time.Max(t => DateTime.Parse(t))).ToList();
從列表中獲取每個對象的最短時間并將其用作比較:
model.AssetTrackers = model.AssetTrackers .OrderByDescending(x => x.time.Min(t => DateTime.Parse(t))).ToList();
我想,第三種選擇是取平均值,這會有點不同,因為它需要數字類型,而不是日期。但幸運的是,我們可以使用Ticks
屬性進行比較:
從列表中獲取每個對象的最短時間并將其用作比較:
model.AssetTrackers = model.AssetTrackers .OrderByDescending(x => x.time.Average(t => DateTime.Parse(t).Ticks)).ToList();
無論如何,如果您將屬性存儲為(最好是 UTC)DateTime
對象而不是字符串,生活會簡單得多。如果輸入是沿線某處的字符串,最好預先排除任何解析錯誤,而不是在我們稍后嘗試處理數據時。
- 3 回答
- 0 關注
- 204 瀏覽
添加回答
舉報