溫馨提示×

c# orderby如何使用

c#
小樊
82
2024-11-18 19:41:25
欄目: 編程語言

在C#中,OrderBy是LINQ(Language Integrated Query)中的一個非常常用的方法,用于對集合中的元素進行排序。以下是一些基本示例,說明如何在C#中使用OrderBy方法。

首先,確保你已經(jīng)引入了System.Linq命名空間,這樣你才能使用LINQ查詢。

對集合進行排序

假設你有一個List<int>類型的集合,并且你想根據(jù)集合中每個元素的值進行升序排序。

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作為參數(shù),該表達式表示對每個元素使用其本身的值進行排序。結(jié)果是一個新的已排序的集合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作為參數(shù),但返回的結(jié)果是降序排列的。

對集合進行多列排序

你還可以使用OrderByThenBy方法對集合進行多列排序。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屬性進行排序。

0