我在Framework 3.5上使用c#。我想快速排序一个通用列表<T>。对于这个例子,假设我有一个List of a Person类型,其属性为lastname。如何使用lambda表达式对这个列表进行排序?
List<Person> people = PopulateList();
people.OrderBy(???? => ?????)
我在Framework 3.5上使用c#。我想快速排序一个通用列表<T>。对于这个例子,假设我有一个List of a Person类型,其属性为lastname。如何使用lambda表达式对这个列表进行排序?
List<Person> people = PopulateList();
people.OrderBy(???? => ?????)
当前回答
private void SortGridGenerico< T >(
ref List< T > lista
, SortDirection sort
, string propriedadeAOrdenar)
{
if (!string.IsNullOrEmpty(propriedadeAOrdenar)
&& lista != null
&& lista.Count > 0)
{
Type t = lista[0].GetType();
if (sort == SortDirection.Ascending)
{
lista = lista.OrderBy(
a => t.InvokeMember(
propriedadeAOrdenar
, System.Reflection.BindingFlags.GetProperty
, null
, a
, null
)
).ToList();
}
else
{
lista = lista.OrderByDescending(
a => t.InvokeMember(
propriedadeAOrdenar
, System.Reflection.BindingFlags.GetProperty
, null
, a
, null
)
).ToList();
}
}
}
其他回答
你可以使用下面的代码片段:
var New1 = EmpList.OrderBy(z => z.Age).ToList();
其中New1是一个<员工>的列表。
EmpList是List<Employee>的变量。
z是Employee类型的变量。
如果你指的是就地排序(即更新列表):
people.Sort((x, y) => string.Compare(x.LastName, y.LastName));
如果你指的是新列表:
var newList = people.OrderBy(x=>x.LastName).ToList(); // ToList optional
people.OrderBy(person => person.lastname).ToList();
这是一个通用的排序器。用下面的开关调用。
数字式电压表。PagePermissions是ViewModel类型上的一个属性 在本例中,List T是一个名为page_permission的EF6模型类。
数字式电压表。UserNameSortDir是视图模型上的一个字符串属性,用于保存下一个排序方向。视图中实际使用的那个。
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;
}
你可以使用linq:)使用:
System.linq;
var newList = people.OrderBy(x=>x.Name).ToList();