c# - 列表<> OrderBy按字母顺序


我在Framework 3.5上使用C#。 我正在寻找快速排序通用List<> 。 为了这个例子,我们可以说我有一个人姓名类型的名单与姓氏属性。 我将如何使用lambda表达式对此列表进行排序?

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

Answers


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

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

如果你的意思是新的名单:

var newList = people.OrderBy(x=>x.LastName).ToList(); // ToList optional



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

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

要进行排序,您需要一个IComparer<Person>或一个Comparison<Person> 。 为此,您可能希望考虑MiscUtil中的 ProjectionComparer

(我知道我一直把MiscUtil带上去 - 它只是保持相关...)




people.OrderBy(person => person.lastname).ToList();



你可以使用linq :)使用:

System.linq;
var newList = people.OrderBy(x=>x.Name).ToList();



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();
        }
    }
}



对我来说, 这个有用的虚拟指导 - 在通用列表中排序 -工作。 通过非常全面和清晰的解释和简单的例子,帮助你理解4种方式(超负荷)来完成这项工作

  • List.Sort()
  • List.Sort(通用比较)
  • List.Sort(通用IComparer)
  • List.Sort(Int32,Int32,通用IComparer)



你可以使用这个代码片段:

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

其中New1是一个List<Employee>

EmpList是一个List<Employee>变量。

zEmployee类型的变量。




你也可以使用

model.People = model.People.OrderBy(x => x.Name).ToList();



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

dvm.PagePermissions是List Model T的ViewModel上的一个属性,在这种情况下,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;
    }