亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何編寫 linq 查詢以按時間戳排序

如何編寫 linq 查詢以按時間戳排序

C#
慕桂英546537 2022-01-15 15:39:46
我想通過按時間戳降序來保持對象列表的順序。收到錯誤消息 - 無法將列表轉換為字符串。模型的采樣時間2018 年 12 月 9 日晚上 11:24:37 public ActionResult A() {     var model = new AssetTrackersViewModel();     model.AssetTrackers.Add(getAssetDetails_CH("e8", DateTime.Now.Date, DateTime.Now.Date));     model = model.AssetTrackers.OrderByDescending(x => DateTime.Parse(x.time));//error      return View(model); }班級 public class AssetTracker {    public AssetTracker()    {        latitude = new List<string>();        longitude = new List<string>();        time = new List<string>();    }    public string deviceid { get; set; }    public List<string> latitude { get; set; }    public List<string> longitude { get; set; }    public List<string> time { get; set; }               }public class AssetTrackersViewModel{    public AssetTrackersViewModel()    {        AssetTrackers = new List<AssetTracker>();    }        public List<AssetTracker> AssetTrackers { get; set; }}
查看完整描述

3 回答

?
RISEBY

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 的額外成本。


查看完整回答
反對 回復 2022-01-15
?
largeQ

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

}


查看完整回答
反對 回復 2022-01-15
?
撒科打諢

TA貢獻1934條經驗 獲得超2個贊

time是(并且不能是,這就是您收到錯誤的原因)的List<string>屬性。您想如何根據每個項目的時間屬性進行排序?換句話說,您想如何將一個時間列表與另一個時間列表進行比較以確定排序順序?AssetTrackerDateTimeParseList<string>List<AssetTracker>

由于您正在比較 a 屬性上的對象List<string>,因此您需要某種方法來確定該屬性值的基線。我想到了兩種方法:MinMax

  1. 從列表中獲取每個對象的最大時間并將其用作比較:

    model.AssetTrackers = model.AssetTrackers    .OrderByDescending(x => x.time.Max(t => DateTime.Parse(t))).ToList();

  2. 從列表中獲取每個對象的最短時間并將其用作比較:

    model.AssetTrackers = model.AssetTrackers    .OrderByDescending(x => x.time.Min(t => DateTime.Parse(t))).ToList();

我想,第三種選擇是取平均值,這會有點不同,因為它需要數字類型,而不是日期。但幸運的是,我們可以使用Ticks屬性進行比較:

  1. 從列表中獲取每個對象的最短時間并將其用作比較:

    model.AssetTrackers = model.AssetTrackers    .OrderByDescending(x => x.time.Average(t => DateTime.Parse(t).Ticks)).ToList();

無論如何,如果您將屬性存儲為(最好是 UTC)DateTime對象而不是字符串,生活會簡單得多。如果輸入是沿線某處的字符串,最好預先排除任何解析錯誤,而不是在我們稍后嘗試處理數據時。


查看完整回答
反對 回復 2022-01-15
  • 3 回答
  • 0 關注
  • 204 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號