List <T> OrderBy по алфавиту

443

Я использую C # на Framework 3.5. Я ищу, чтобы быстро отсортировать Generic List<T>. Для примера, скажем, у меня есть список Personтипа со свойством фамилия. Как бы отсортировать этот список с помощью лямбда-выражения?

List<Person> people = PopulateList();
people.OrderBy(???? => ?????)
SaaS Developer
источник

Ответы:

696

Если вы имеете в виду сортировку на месте (т.е. список обновляется):

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

Если вы имеете в виду новый список:

var newList = people.OrderBy(x=>x.LastName).ToList(); // ToList optional
Марк Гравелл
источник
2
Я считаю, что первым хочет быть people.Sort ((x, y) => string.Compare (x.LastName, y.LastName) <0);
Джеймс Керран
36
@James: я бы так не думал Сравнение <T> возвращает int, а не bool.
Джон Скит
2
Интересно, если вы хотите заказать имя и фамилию ... что вы должны написать?
balexandre
63
var newList = people.OrderBy (x => x.FirstName) .ThenBy (x => x.LastName) .ToList ();
Марк Гравелл
4
@Faraz (x, y) => x.price.CompareTo (y.price)
Марк Гравелл
98

Вам нужен список для сортировки по месту или просто упорядоченная последовательность содержимого списка? Последнее проще:

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

Для сортировки по месту вам понадобится IComparer<Person>или Comparison<Person>. Для этого вы можете рассмотреть ProjectionComparerв MiscUtil .

(Я знаю, что продолжаю поднимать MiscUtil - он просто продолжает быть актуальным ...)

Джон Скит
источник
1
Это сработало для меня, но только после того, как я добавил ".ToList ()": contemporariesOrderedByBirthYear = contemporaries.OrderBy (contemp => contemp.BirthYear) .ToList ();
Б. Клэй Шеннон
2
@ B.ClayShannon: Ну, это нужно, если вы хотите List<T>, но вам это не нужно, если вы просто хотите повторить.
Джон Скит
23

Вы можете использовать linq :) используя:

System.linq;
var newList = people.OrderBy(x=>x.Name).ToList();
vampire203
источник
23
people.OrderBy(person => person.lastname).ToList();
Danimal
источник
17
Ну, это все еще не отражает результат - вам понадобится «List <Person> people =» с левой стороны ...
Марк Грэвелл
8
Этот ответ демонстрирует наиболее распространенную ошибку при использовании LINQ - такие методы, как OrderBy не модифицировать список, а скорее возвращают новую «коллекцию» (обычно ленивую IEnumerable<T>), которую нужно назначить чему-либо.
Алексей Левенков
2
@AlexeiLevenkov откуда вы знаете, что это самая распространенная ошибка при использовании LINQ?
Tymtam
13
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();
        }
    }
}
Bruno
источник
5

для меня это полезное руководство - сортировка в общем списке - сработало. это поможет вам понять 4 способа (перегрузки), чтобы сделать эту работу с очень полными и ясными объяснениями и простыми примерами

  • List.Sort ()
  • List.Sort (общее сравнение)
  • List.Sort (Общий IComparer)
  • List.Sort (Int32, Int32, универсальный IComparer)
Иман
источник
5

Вы можете использовать этот фрагмент кода:

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

где New1это List<Employee>.

EmpListявляется переменной List<Employee>.

zпеременная Employeeтипа.

АншуМан СривАстав
источник
AnshuMan, нет ничего похожего на varтип. New1есть List<Employee>и zесть Employee.
Nawfal
5

Вы также можете использовать

model.People = model.People.OrderBy(x => x.Name).ToList();
rosselder83
источник
4
Хотя этот пример кода может ответить на вопрос, в нем нет объяснения. Как он стоит сейчас, он не добавляет никакой ценности и выдерживает изменение, которое было понижено / удалено. Пожалуйста, добавьте некоторые объяснения, что делает и почему это решение проблемы ОП.
oɔɯǝɹ
0

Это универсальный сортировщик. Вызывается с помощью переключателя ниже.

dvm.PagePermissions - это свойство в моей ViewModel типа List T, в этом случае T - это класс модели EF6, называемый page_permission.

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;
    }
howserss
источник
1
Я думаю, что это слишком сложно. Как вы можете видеть в других ответах, все это может быть сделано в одной строке (это не обязательно означает, что делать это в одной строке хорошо, но я не получаю преимущества от этого)
Jalgames
Это для многостолбцовой сортировки с использованием AngularJS. По сути, это сортировка одной строкой, но она также устанавливает переменную направления сортировки. Это действительно не так сложно, если вы посмотрите на это внимательно. Я полагаю, что функция Sort немного пугает всеми типичными вещами, но если я исключу это определение, то это вызов Sort из 1 строки.
howserss
Слишком сложный для того, что запросили Op. Это хорошее решение для другой проблемы.
катит