温馨提示×

c# orderby如何使用

c#
小樊
81
2024-11-18 19:41:25
栏目: 编程语言

在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作为参数,但返回的结果是降序排列的。

对集合进行多列排序

你还可以使用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