我有一个关于按多个列排序列表的问题。在下面的示例中,即使我已经排好序以显示None, A First Description, B Second...
,该列表仍然按插入顺序打印。
List<MySample> samples = new List<MySample>();
samples.Add(new MySample { SortOrder = 1, Data = "A First Description", Description = "A First Description" });
samples.Add(new MySample { SortOrder = 1, Data = "C Third Description", Description = "C Third Description" });
samples.Add(new MySample { SortOrder = 1, Data = "B Second Description", Description = "B Second Description" });
samples.Add(new MySample { SortOrder = 0, Data = "None", Description = "None" });
samples.OrderBy(a => a.SortOrder).ThenBy(a => a.Description).ToList();
foreach (var item in samples)
{
Console.WriteLine(item);
}
public class MySample
{
public int SortOrder { get; set; }
public string Description { get; set; }
public object Data { get; set; }
}
如果我将代码更改为以下内容,则可以按所需顺序打印。
samples = samples.OrderBy(a => a.SortOrder).ThenBy(a => a.Description).ToList();
可以不分配(像上面那样)就进行排序吗?
顺便说一下,这个示例不是实际代码。我需要通过代码后台使用FrameworkElementFactory
将此列表数据绑定到WPF
中的ComboBox
。
感谢您的帮助!
使用我的方法进行更新:
var collectionView = CollectionViewSource.GetDefaultView(<My list to be sorted>);
collectionView.SortDescriptions.Add(new SortDescription("SortOrder", ListSortDirection.Ascending));
collectionView.SortDescriptions.Add(new SortDescription("Description", ListSortDirection.Ascending));
上述方法已在用户界面中实现。感谢所有人的快速回答。
List
提供了一个不需要赋值的Sort
函数,但它更复杂,因为它涉及编写自己的比较器。 - Kendall Frey