C# 按表格中的某列排序/查询

cs 复制代码
using System;
using System.Data;
using System.Linq;

class Program
{
    static void Main()
    {
        // 创建一个示例的 DataTable 对象
        DataTable table = new DataTable();
        table.Columns.Add("ID", typeof(int));
        table.Columns.Add("Name", typeof(string));

        table.Rows.Add(1, "John");
        table.Rows.Add(2, "Jane");
        table.Rows.Add(3, "Bob");
        table.Rows.Add(4, "Alice");

        // 要查找的数据
        int targetID = 3;

        // 使用 LINQ 查询获取数据所在的行号
        var rows = table.AsEnumerable()
            .Select((row, index) => new { Row = row, Index = index })
            .Where(x => x.Row.Field<int>("ID") == targetID)
            .ToList();

        if (rows.Count > 0)
        {
            int rowIndex = rows[0].Index;
            Console.WriteLine("数据所在的行号为: " + rowIndex);
        }
        else
        {
            Console.WriteLine("未找到匹配的数据");
        }
    }
}

这段代码使用 LINQ 查询语句来获取表格中指定数据所在的行号:

  1. table.AsEnumerable() : 这将将 DataTable 对象转换为可枚举的集合,以便能够在 LINQ 查询中使用。

  2. .Select((row, index) => new { Row = row, Index = index }): 这一部分使用 Select 方法来创建一个新的匿名对象,其中包含每一行的数据以及行号。row 是每一行的数据,index 是行号。

  3. .Where(x => x.Row.Field<int>("ID") == targetID): 这一部分使用 Where 方法来筛选出符合条件的行,其中条件是行的 "ID" 列的值等于目标 ID 值 targetID

  4. .ToList(): 最后,使用 ToList 方法将查询结果转换为列表,以便我们可以进一步处理。 综上所述,这段代码的作用是在表格中查找满足指定条件的行,并将这些行的数据以及对应的行号存储在一个列表中。

cs 复制代码
using System;
using System.Data;
using System.Linq;

class Program
{
    static void Main()
    {
        // 创建一个示例的 DataTable 对象
        DataTable table = new DataTable();
        table.Columns.Add("ID", typeof(int));
        table.Columns.Add("Name", typeof(string));

        table.Rows.Add(2, "Jane");
        table.Rows.Add(4, "Alice");
        table.Rows.Add(1, "John");
        table.Rows.Add(3, "Bob");

        // 按照 "ID" 列的值进行升序排序
        var sortedRows = table.AsEnumerable()
            .OrderBy(row => row.Field<int>("ID"))
            .ToList();

        // 输出排序后的结果
        foreach (DataRow row in sortedRows)
        {
            Console.WriteLine(row["ID"] + "\t" + row["Name"]);
        }
    }
}

这段代码使用 LINQ 查询语句对 DataTable 中的数据进行排序:

  1. table.AsEnumerable(): 这将将 DataTable 对象转换为可枚举的集合,以便能够在 LINQ 查询中使用。

  2. .OrderBy(row => row.Field<int>("ID")): 这一部分使用 OrderBy 方法对可枚举集合中的元素进行排序。row => row.Field<int>("ID") 是一个 lambda 表达式,它指定了排序的规则。在这个示例中,我们按照每一行的 "ID" 列的值进行排序。

  3. .ToList(): 最后,使用 ToList 方法将排序后的结果转换为列表,以便我们可以进一步处理或输出。

综上所述,这段代码的作用是对 DataTable 中的数据按照指定列进行升序排序,并将排序结果存储在一个列表中。你可以根据需要对其他列进行排序,或者进一步处理排序后的结果,比如输出到控制台或存储到其他数据结构中。在示例中,我们将排序后的结果存储在 sortedRows 列表中。

相关推荐
坚果派·白晓明2 小时前
【鸿蒙PC三方库移植适配框架解读系列】第八篇:扩展lycium框架使其满足rust三方库适配
c语言·开发语言·华为·rust·harmonyos·鸿蒙
花间相见2 小时前
【PaddleOCR教程01】PP-OCRv5 全面指南:从模型架构到实战部署
开发语言·r语言
小短腿的代码世界2 小时前
Qt 股票订单撮合引擎:高频交易系统的核心心脏
开发语言·数据库·qt·系统架构·交互
光泽雨3 小时前
c#中的“跨界找人”
c#
谙弆悕博士4 小时前
快速学C语言——第16章:预处理
c语言·开发语言·chrome·笔记·创业创新·预处理·业界资讯
yuan199974 小时前
基于 C# 实现的 Omron HostLink (FINS) 协议 PLC 通讯
开发语言·c#
qq_422828625 小时前
android图形学之SurfaceControl和Surface的关系 五
android·开发语言·python
如竟没有火炬6 小时前
用队列实现栈
开发语言·数据结构·python·算法·leetcode·深度优先
火星papa6 小时前
C# 任务(Task)的基础实现
c#·任务·task
折哥的程序人生 · 物流技术专研6 小时前
《Java 100 天进阶之路》第17篇:Java常用包装类与自动装箱拆箱深入
java·开发语言·后端·面试