鉴于以下情况:
public class Foo
{
/* other properties */
public Int32 Id { get; set; }
}
var listOfFoo = new[]{
new Foo { Id = 1 },
new Foo { Id = 2 },
new Foo { Id = 3 }
};
var sortOrderIds = new[]{
2, 3, 1
};
如果我想对 listOfFoo
进行排序,使 Id
的最终顺序与 sortOrderIds
中显示的顺序相同,最好的方法是什么?我想我可以使用类似的方法进行排序:
Int32 SortUsingIdArrayAsReference(Foo x, Foo y)
{
// creative license on "IndexOf", bear with me
return Int32.CompareTo(sortOrderids.IndexOf(x.Id), sortOrderIds.indexOf(y.Id));
}
但这真的是最好的方法吗?我希望 LINQ 可能有更好的东西我可以使用,但如果没有的话也好。只是寻找其他输入,看看其他人是否有更好的方法。
最佳答案
您可以使用List.IndexOf
var ordered = listOfFoo.OrderBy(o => sortOrderIDs.IndexOf(o.Id));
编辑:由于 sortOrderIDs
是一个数组:
var ordered = listOfFoo.OrderBy(o => Array.IndexOf(sortOrderIds, o.Id));
或者,如果您想对列表和数组使用相同的方法,请将其转换为 IList
:
var ordered = listOfFoo.OrderBy(o => ((IList)sortOrderIds).IndexOf(o.Id));
关于c# - 按属性和这些属性的有序数组对 IEnumerable<Object> 进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14511749/