Ответ 1
Используя методы расширения, сначала OrderBy
имя перечисления, ThenBy
.
var sorted = list.OrderBy( m => m.Sort ).ThenBy( m => m.Name );
У меня есть примерный класс, содержащий две точки данных:
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, которое я делаю Не знаю.
Используя методы расширения, сначала OrderBy
имя перечисления, ThenBy
.
var sorted = list.OrderBy( m => m.Sort ).ThenBy( m => m.Name );
Помимо хороших решений 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()
, и он выведет правильный порядок.
Это должно сделать это, я думаю,
var result = from m in list
orderby m.Sort, m.Name
select m;