我在Framework 3.5上使用C#。 我想快速排序通用List<T>
。 为了这个例子,假设我有一个具有lastname属性的Person
类型的List。 如何使用lambda表达式对此List进行排序?
List<Person> people = PopulateList();
people.OrderBy(???? => ?????)
#1楼
您可以使用此代码段:
var New1 = EmpList.OrderBy(z => z.Age).ToList();
其中New1
是List<Employee>
。
EmpList
是List<Employee>
变量。
z
是Employee
类型的变量。
#2楼
people.OrderBy(person => person.lastname).ToList();
#3楼
您是否需要对列表进行分类,或者只是列表内容的有序序列? 后者更容易:
var peopleInOrder = people.OrderBy(person => person.LastName);
要进行排序,您需要IComparer<Person>
或Comparison<Person>
。 为此,您可能希望在MiscUtil中考虑ProjectionComparer
。
(我知道我一直把MiscUtil搞定 - 它只是保持相关......)
#4楼
如果您的意思是就地排序(即列表已更新):
people.Sort((x, y) => string.Compare(x.LastName, y.LastName));
如果你的意思是新的清单:
var newList = people.OrderBy(x=>x.LastName).ToList(); // ToList optional
#5楼
这是一个通用的分拣机。 用下面的开关调用。
dvm.PagePermissions是我的ViewModel类型为List T的属性,在这种情况下,T是一个名为page_permission的EF6模型类。
dvm.UserNameSortDir是viewmodel上的字符串属性,用于保存下一个排序方向。 在视图中被动态使用的那个。
switch (sortColumn)
{
case "user_name":
dvm.PagePermissions = Sort(dvm.PagePermissions, p => p.user_name, ref sortDir);
dvm.UserNameSortDir = sortDir;
break;
case "role_name":
dvm.PagePermissions = Sort(dvm.PagePermissions, p => p.role_name, ref sortDir);
dvm.RoleNameSortDir = sortDir;
break;
case "page_name":
dvm.PagePermissions = Sort(dvm.PagePermissions, p => p.page_name, ref sortDir);
dvm.PageNameSortDir = sortDir;
break;
}
public List<T> Sort<T,TKey>(List<T> list, Func<T, TKey> sorter, ref string direction)
{
if (direction == "asc")
{
list = list.OrderBy(sorter).ToList();
direction = "desc";
}
else
{
list = list.OrderByDescending(sorter).ToList();
direction = "asc";
}
return list;
}
来源:oschina
链接:https://my.oschina.net/stackoom/blog/3162206