Учитывая список Location
, мне нужно сделать 2 порядка.
LocationType
возрастанию.Name
возрастанию.Пример данных:
Location Type | Name
2 | Templestowe Lower
2 | Templestowe
1 | Melbourne
Ожидаемые результаты:
1. Melbourne
2. Templestowe
3. Templestowe Lower
Вот (не работает).NET Fiddle...
и вот главный код (скопированный с этой скрипки)..
private class Location
{
public Location (string name, int locationType)
{
Name = name;
LocationType = locationType;
}
public string Name { get; private set; }
public int LocationType { get; private set;}
}
public static void Main()
{
var locations = new List<Location>
{
new Location("Templestowe Lower", 2),
new Location("Templestowe", 2),
new Location("Melbourne", 1)
};
// TODO: return a list, sorted by LocationType and name.
var results = XXXXX;
foreach(var location in results)
{
Console.WriteLine(location.Name);
}
}
locations.Sort((x,y) => {
int delta = x.LocationType.CompareTo(y.LocationType);
if(delta == 0) delta = string.Compare(x.Name, y.Name);
return delta;
});
В качестве альтернативы:
var results = locations.OrderBy(x => x.LocationType).ThenBy(x => x.Name);
Или в синтаксисе LINQ (компилируется одно и то же):
var results = from loc in locations
orderby loc.LocationType, loc.Name
select loc;
Проверьте это, используя
var results = locations
.GroupBy(x => x.LocationType)
.OrderBy(x => x.Key)
.SelectMany(g => g.OrderBy(x=>x.Name));