第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

如何編寫 linq 查詢以按時(shí)間戳排序

如何編寫 linq 查詢以按時(shí)間戳排序

C#
慕桂英546537 2022-01-15 15:39:46
我想通過按時(shí)間戳降序來保持對(duì)象列表的順序。收到錯(cuò)誤消息 - 無法將列表轉(zhuǎn)換為字符串。模型的采樣時(shí)間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); }班級(jí) 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貢獻(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 的額外成本。


查看完整回答
反對(duì) 回復(fù) 2022-01-15
?
largeQ

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

}


查看完整回答
反對(duì) 回復(fù) 2022-01-15
?
撒科打諢

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)行比較以確定排序順序?AssetTrackerDateTimeParseList<string>List<AssetTracker>

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

  1. 從列表中獲取每個(gè)對(duì)象的最大時(shí)間并將其用作比較:

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

  2. 從列表中獲取每個(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)行比較:

  1. 從列表中獲取每個(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í)。


查看完整回答
反對(duì) 回復(fù) 2022-01-15
  • 3 回答
  • 0 關(guān)注
  • 200 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)