473

我在 Framework 3.5 上使用 C#。我正在寻找快速排序 Generic List<T>。为了这个例子,假设我有一个Person类型为姓氏的列表。我将如何使用 lambda 表达式对该列表进行排序?

List<Person> people = PopulateList();
people.OrderBy(???? => ?????)
4

9 回答 9

727

如果您的意思是就地排序(即更新列表):

people.Sort((x, y) => string.Compare(x.LastName, y.LastName));

如果您的意思是新列表:

var newList = people.OrderBy(x=>x.LastName).ToList(); // ToList optional
于 2008-10-09T16:49:55.587 回答
105

您是否需要对列表进行就地排序,或者只是列表内容的有序序列?后者更容易:

var peopleInOrder = people.OrderBy(person => person.LastName);

要就地排序,您需要一个IComparer<Person>或一个Comparison<Person>. 为此,您不妨考虑ProjectionComparerMiscUtil中。

(我知道我一直在提出 MiscUtil - 它只是一直相关......)

于 2008-10-09T16:49:50.267 回答
24
people.OrderBy(person => person.lastname).ToList();
于 2008-10-09T16:48:44.153 回答
24

您可以使用 linq :) 使用:

System.linq;
var newList = people.OrderBy(x=>x.Name).ToList();
于 2011-07-28T21:11:17.067 回答
15
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();
        }
    }
}
于 2010-12-08T13:12:34.767 回答
6

对我来说,这个有用的虚拟指南 - 在通用列表中排序 - 有效。它通过非常完整和清晰的解释和简单的示例帮助您了解完成这项工作的 4 种方法(重载)

  • 列表.排序()
  • List.Sort(通用比较)
  • List.Sort(通用 IComparer)
  • List.Sort (Int32, Int32, Generic IComparer)
于 2011-01-29T07:27:47.477 回答
5

您可以使用此代码段:

var New1 = EmpList.OrderBy(z => z.Age).ToList();

哪里New1List<Employee>

EmpList是 a 的变量List<Employee>

zEmployee类型变量。

于 2013-04-01T13:28:19.160 回答
5

你也可以使用

model.People = model.People.OrderBy(x => x.Name).ToList();
于 2015-02-02T08:59:43.747 回答
2

这是一个通用的分拣机。用下面的开关调用。

dvm.PagePermissions 是我的 ViewModel 上的 List T 类型的一个属性,在这种情况下,T 是一个名为 page_permission 的 EF6 模型类。

dvm.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;
    }
于 2014-02-01T20:15:13.210 回答