在C#中,OrderBy
是LINQ(Language Integrated Query)中的一個非常常用的方法,用于對集合中的元素進行排序。以下是一些基本示例,說明如何在C#中使用OrderBy
方法。
首先,確保你已經引入了System.Linq
命名空間,這樣你才能使用LINQ查詢。
假設你有一個List<int>
類型的集合,并且你想根據集合中每個元素的值進行升序排序。
using System;
using System.Collections.Generic;
using System.Linq;
class Program
{
static void Main()
{
List<int> numbers = new List<int> { 3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5 };
// 使用OrderBy方法對numbers列表進行升序排序
var sortedNumbers = numbers.OrderBy(n => n);
// 打印排序后的列表
foreach (var number in sortedNumbers)
{
Console.WriteLine(number);
}
}
}
在這個例子中,OrderBy
方法接受一個lambda表達式n => n
作為參數,該表達式表示對每個元素使用其本身的值進行排序。結果是一個新的已排序的集合sortedNumbers
。
如果你想對集合進行降序排序,可以使用OrderByDescending
方法。這個方法的工作方式與OrderBy
類似,但它返回一個降序排列的集合。
using System;
using System.Collections.Generic;
using System.Linq;
class Program
{
static void Main()
{
List<int> numbers = new List<int> { 3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5 };
// 使用OrderByDescending方法對numbers列表進行降序排序
var sortedNumbers = numbers.OrderByDescending(n => n);
// 打印排序后的列表
foreach (var number in sortedNumbers)
{
Console.WriteLine(number);
}
}
}
在這個例子中,OrderByDescending
方法同樣接受一個lambda表達式n => n
作為參數,但返回的結果是降序排列的。
你還可以使用OrderBy
和ThenBy
方法對集合進行多列排序。ThenBy
方法允許你在一個已排序的序列上添加額外的排序條件。
using System;
using System.Collections.Generic;
using System.Linq;
class Program
{
static void Main()
{
List<Employee> employees = new List<Employee>
{
new Employee { Name = "John", Age = 30, Department = "HR" },
new Employee { Name = "Jane", Age = 28, Department = "IT" },
new Employee { Name = "Sam", Age = 35, Department = "IT" },
new Employee { Name = "Anna", Age = 25, Department = "HR" }
};
// 使用OrderBy和ThenBy方法對employees列表進行多列排序
var sortedEmployees = employees.OrderBy(e => e.Age) // 首先按年齡升序排序
.ThenBy(e => e.Department); // 然后按部門排序
// 打印排序后的列表
foreach (var employee in sortedEmployees)
{
Console.WriteLine($"{employee.Name}, {employee.Age}, {employee.Department}");
}
}
}
class Employee
{
public string Name { get; set; }
public int Age { get; set; }
public string Department { get; set; }
}
在這個例子中,我們首先按Age
屬性升序排序,然后使用ThenBy
方法按Department
屬性進行排序。