c# OrderBy 实现List升序降序

1)前台代码

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="WebApplication8.Default" %>


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">


<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <asp:GridView ID="GridView1" runat="server">
        </asp:GridView>
    </div>
    </form>
</body>
</html>

2)后台代码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;


namespace WebApplication8
{
    public partial class Default : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {
                BindStudents();
            }
        }
        private void BindStudents()
        {
            List<Student> items = GetStudents().OrderBy(u => u.Name).ToList();//order by name asc
            //List<Student> items = GetStudents().OrderByDescending(u => u.Name).ToList();//order by name desc
            GridView1.DataSource = items;
            GridView1.DataBind();
        }
        private List<Student> GetStudents()
        {
            List<Student> items = new List<Student>();
            items.Add(new Student
            {
                ID = 2,
                Name = "abd"
            });
            items.Add(new Student
            {
                ID = 1,
                Name = "abc"
            });
            items.Add(new Student
            {
                ID = 3,
                Name = "bcd"
            });
            items.Add(new Student
            {
                ID = 4,
                Name = "acd"
            });
            return items;
        }
    }
    public class Student
    {
        public int ID { set; get; }
        public string Name { set; get; }
    }
}


  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C#中的`orderby`是用于对集合进行排序的关键字。它可以用于对单个属性或多个属性进行排序,也可以指定升序降序排列。`orderby`通常与`linq`一起使用,用于对集合进行查询和筛选。 以下是一个简单的示例,演示如何使用`orderby`对一个整数数组进行排序: ``` int[] numbers = { 5, 2, 8, 1, 9 }; var sortedNumbers = from num in numbers orderby num ascending select num; foreach (var num in sortedNumbers) { Console.WriteLine(num); } ``` 在上面的示例中,我们使用`orderby`对整数数组进行升序排序,并将结果存储在一个变量中。然后,我们使用`foreach`循环遍历排序后的结果,并将每个数字打印到控制台上。 除了对单个属性进行排序外,`orderby`还可以用于对多个属性进行排序。例如,如果我们有一个包含学生姓名和年龄的集合,我们可以使用以下代码按照年龄和姓名的顺序对其进行排序: ``` List<Student> students = new List<Student>(); students.Add(new Student { Name = "Alice", Age = 20 }); students.Add(new Student { Name = "Bob", Age = 18 }); students.Add(new Student { Name = "Charlie", Age = 22 }); var sortedStudents = from student in students orderby student.Age ascending, student.Name ascending select student; foreach (var student in sortedStudents) { Console.WriteLine(student.Name + " - " + student.Age); } ``` 在上面的示例中,我们首先创建了一个包含学生姓名和年龄的集合。然后,我们使用`orderby`对学生集合进行排序,首先按照年龄升序排列,然后按照姓名升序排列。最后,我们使用`foreach`循环遍历排序后的结果,并将每个学生的姓名和年龄打印到控制台上。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值