List OrderBy по алфавиту

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

List<Person> people = PopulateList();
people.OrderBy(???? => ?????)
9.10.2008 16:48:03
9 ОТВЕТОВ
РЕШЕНИЕ

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

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

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

var newList = people.OrderBy(x=>x.LastName).ToList(); // ToList optional
689
9.10.2008 16:49:55
Я считаю, что первым хочет быть people.Sort ((x, y) => string.Compare (x.LastName, y.LastName) <0);
James Curran 9.10.2008 16:56:37
@James: я бы так не думал Сравнение <T> возвращает int, а не bool.
Jon Skeet 9.10.2008 16:59:25
Интересно, если вы хотите заказать имя и фамилию ... что вы должны написать?
balexandre 16.04.2009 07:03:08
var newList = people.OrderBy (x => x.FirstName) .ThenBy (x => x.LastName) .ToList ();
Marc Gravell♦ 16.04.2009 07:36:13
@Faraz (x, y) => x.price.CompareTo (y.price)
Marc Gravell♦ 16.02.2014 18:18:08
people.OrderBy(person => person.lastname).ToList();
23
22.11.2011 08:36:30
Что ж, это все еще не отражает результат - вам понадобится «List <Person> people =» с левой стороны ...
Marc Gravell♦ 9.10.2008 17:10:14
Этот ответ демонстрирует наиболее распространенную ошибку при использовании LINQ - такие методы, как OrderBy не модифицировать список, а скорее возвращают новую «коллекцию» (обычно ленивую IEnumerable<T>), которую нужно назначить чему-либо.
Alexei Levenkov 31.08.2015 20:41:38
@AlexeiLevenkov откуда вы знаете, что это самая распространенная ошибка при использовании LINQ?
tymtam 2.03.2016 05:58:38

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

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

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

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

98
9.10.2008 16:49:50
Это сработало для меня, но только после того, как я добавил ".ToList ()": contemporariesOrderedByBirthYear = contemporaries.OrderBy (contemp => contemp.BirthYear) .ToList ();
B. Clay Shannon 25.08.2016 18:20:06
@ B.ClayShannon: Ну, это нужно, если вы хотите List<T>, но вам это не нужно, если вы просто хотите повторить.
Jon Skeet 25.08.2016 20:48:01
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();
        }
    }
}
13
22.11.2011 09:22:43

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

  • List.Sort ()
  • List.Sort (общее сравнение)
  • List.Sort (Общий IComparer)
  • List.Sort (Int32, Int32, универсальный IComparer)
5
16.06.2012 11:47:36

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

System.linq;
var newList = people.OrderBy(x=>x.Name).ToList();
23
28.07.2011 22:08:30

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

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

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

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

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

5
19.07.2014 21:32:49
AnshuMan, нет ничего похожего на varтип. New1есть List<Employee>и zесть Employee.
nawfal 30.05.2013 09:05:40

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

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;
    }
0
19.07.2014 21:33:41
Я думаю, что это слишком сложно. Как вы можете видеть в других ответах, все это может быть сделано в одной строке (это не обязательно означает, что делать это в одной строке хорошо, но я не получаю преимущества от этого)
jalgames 19.07.2014 21:29:30
Это для сортировки нескольких столбцов с использованием AngularJS. По сути, это сортировка одной строкой, но она также устанавливает переменную направления сортировки. Это действительно не так сложно, если вы посмотрите на это внимательно. Я полагаю, что функция Sort немного пугает всеми типичными вещами, но если я исключу это определение, то это вызов Sort из 1 строки.
howserss 8.08.2014 14:23:00
Слишком сложный для того, что запросили Op. Это хорошее решение для другой проблемы.
rolls 26.07.2017 00:19:23

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

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