簡體   English   中英

按數組元素排序 Linq 列表

[英]Ordering Linq list by array elements

我有以下代碼 -

var refNosToOrder = new int[9] {1,2,3,4,5,6,7,8,9}

var orderedList = lst.OrderBy(x=>x.RefNo==7)
                     .ThenBy(y=> refNosToOrder.Contains(y.RefNo)).ToList();

lst是包含 int 屬性的 class object 的列表 - RefNo: ie List<SampleClass>

class SampleClass
{
  public int RefNo {get;set;}
}

lst包含RefNo的所有未排序數據:

lst = 2,4,6,9,7,5,8,1,3

我想做的事 -

首先,我想通過將第一個元素保留為 - 7來訂購lst 那么對於列表的 rest,它應該被排序為數組refNosToOrder

即最終 output 我期望是 -

7,1,2,3,4,5,6,8,9

使用上面的代碼 -

var orderedList = lst.OrderBy(x=>x.RefNo==7)
                         .ThenBy(y=> refNosToOrder.Contains(y.RefNo)).ToList();

它給出了 - 2,4,6,9,7,5,8,1,3 ,即這個代碼根本沒有對列表進行排序。

Contains返回一個元素是否在列表中的 boolean,這在這里不會很有幫助。 相反,您可以按該元素的索引進行排序:

var orderedList = 
    lst.OrderBy(x => x.RefNo != 7)
       .ThenBy(y => Array.IndexOf(refNosToOrder, y.RefNo))
       .ToList();

編輯:
繼 Jeroen Mostert 的評論之后,這種排序具有二次復雜性。 對於較大refNosToOrder ,首先將數組轉換為訂單字典然后將其用於排序可能更有效:

var orderDict = 
    Enumerable.Range(0, refNosToOrder.Length).ToDictionary(i => refNosToOrder[i]);
var orderedList = 
    lst.OrderBy(x => x.RefNo != 7).ThenBy(y => orderDict[y.RefNo]).ToList();

暫無
暫無

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

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