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