Подтвердить что ты не робот

Сортировка списка по свойству, а затем другому

У меня есть примерный класс, содержащий две точки данных:

public enum Sort { First, Second, Third, Fourth }
public class MyClass
{
    public MyClass(Sort sort, string name) { 
        this.Sort = sort; 
        this.Name = name; 
    }

    public Sort Sort { get; set; }
    public string Name { get; set; }
}

Я ищу, чтобы отсортировать их по группам по свойству Sort, а затем по алфавиту эти группы.

List<MyClass> list = new List<MyClass>() { 
    new MyClass(MyClass.Sort.Third, "B"), 
    new MyClass(MyClass.Sort.First, "D"),
    new MyClass(MyClass.Sort.First, "A"),
    new MyClass(MyClass.Sort.Fourth, "C"),
    new MyClass(MyClass.Sort.First, "AB"),
    new MyClass(MyClass.Sort.Second, "Z"),
};

Тогда вывод будет следующим: (показывая Name)

A
AB
D
Z
B
C

Я смог сделать это, используя foreach, чтобы отделить элементы от множества меньших массивов (сгруппированных по значению перечисления), но это кажется очень утомительным - и я думаю, что должно быть какое-то решение LINQ, которое я делаю Не знаю.

4b9b3361

Ответ 1

Используя методы расширения, сначала OrderBy имя перечисления, ThenBy.

var sorted = list.OrderBy( m => m.Sort ).ThenBy( m => m.Name );

Ответ 2

Помимо хороших решений LINQ, вы также можете сделать это с помощью метода сравнения, как вы упомянули. Создайте MyClass интерфейс IComparable с помощью метода CompareTo, например:

  public int CompareTo(object obj)
  {
      MyClass other = (MyClass)obj;
      int sort = this.srt.CompareTo(other.srt);
      return (sort == 0) ? this.Name.CompareTo(other.Name) : sort;
  }

Вышеуказанный метод будет упорядочивать ваши объекты сначала перечислением, и если значения перечисления равны, он сравнивает имя. Затем просто вызовите list.Sort(), и он выведет правильный порядок.

Ответ 3

Это должно сделать это, я думаю,

var result = from m in list
             orderby m.Sort, m.Name
             select m;