3 回答

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

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

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