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 列表中。

相关推荐
张人玉12 分钟前
C# 通讯关键类的API
开发语言·c#
froginwe1116 分钟前
R 数组:深入解析与高效使用
开发语言
tao35566720 分钟前
【Python刷力扣hot100】283. Move Zeroes
开发语言·python·leetcode
progalchemist36 分钟前
Quick SwiftObjective-C测试框架入门教程
开发语言·其他·objective-c·swift
z日火1 小时前
Java 泛型
java·开发语言
广药门徒1 小时前
Linux(含嵌入式设备如泰山派)VNC 完整配置指南:含开机自启动(适配 Ubuntu/Debian 系)
开发语言·php
不做无法实现的梦~1 小时前
jetson刷系统之后没有浏览器--解决办法
开发语言·javascript·ecmascript
一只小松许️1 小时前
深入理解:Rust 的内存模型
java·开发语言·rust
eqwaak02 小时前
数据预处理与可视化流水线:Pandas Profiling + Altair 实战指南
开发语言·python·信息可视化·数据挖掘·数据分析·pandas