Ela*_*der 4 c# sorting criteria sql-order-by
我正在编写一个C#程序,允许用户指定排序标准.例如,用户只能按"serviceName"排序,或添加其他几个标准,如"isHD"或"isGood".我要问的是,我想使用'.Then By'语句,但用户确定我需要写多少次.
有什么方法可以根据开关/案例块在标准数量上获得一些灵活性?例如
List.OrderBy(t => t.name)
List.OrderBy(t => t.isHD).ThenBy(t => t.name)
List.OrderBy(t => t.isGood).ThenBy(t => t.name).ThenBy(t => t.isHD)
Run Code Online (Sandbox Code Playgroud)
此外,这些标准的顺序将由用户选择.
你可以使用泛型方法:
public List<T> SortBy<T>(List<T> list, params Func<T, object>[] selectors)
{
var ordered = list.OrderBy(selectors[0]);
for (int i = 1; i < selectors.Count(); i++)
{
ordered= ordered.ThenBy(selectors[i]);
}
return ordered.ToList();
}
Run Code Online (Sandbox Code Playgroud)
运行:
SortBy(List, x=>x.name, x=>x.isHD, x=>x.isGood)
Run Code Online (Sandbox Code Playgroud)
这将做:
List.OrderBy(x=>x.name).ThenBy(x=>x.isHD).ThenBy(x=>x.isGood)
Run Code Online (Sandbox Code Playgroud)
可以通过检查选择器是否通过来改进