当前位置: 首页 > news >正文

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

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 方法将查询结果转换为列表,以便我们可以进一步处理。     综上所述,这段代码的作用是在表格中查找满足指定条件的行,并将这些行的数据以及对应的行号存储在一个列表中

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

http://www.lryc.cn/news/102387.html

相关文章:

  • 【Vue】】img使用 :src 动态绑定图片地址,但是加载图片不成功
  • list模拟
  • python字典:怎么取出key对应的值
  • okvis
  • fabric js双击弹出菜单, 双击弹出输入框 修改文字 群组对象
  • 路由器工作原理
  • 在centos 7系统docker上构建mysql 5.7
  • 数据库的介绍和分类
  • 职责链模式——请求的链式处理
  • docker中涉及的挂载点总结
  • elasticsearch 官方优化建议
  • Kubernetes(K8s)从入门到精通系列之五:K8s的基本概念和术语之应用类
  • DevOps(四)
  • Element-plus侧边栏踩坑
  • 支持多种通信方式和协议方便接入第三方服务器或云平台
  • 使用 OpenCV 进行图像模糊度检测(拉普拉斯方差方法)
  • 神经网络简单介绍
  • 16位S912ZVML32F3MKH、S912ZVML31F1WKF、S912ZVML31F1MKH混合信号MCU,适用于汽车和工业电机控制应用。
  • 力扣 509. 斐波那契数
  • 使用 DolphinDB TopN 函数探索高效的Alpha因子
  • 超聚变和厦门大学助力兴业银行构建智慧金融隐私计算平台,助力信用卡业务精准营销...
  • docker 的compose安装
  • JavaScript---事件对象event
  • Day 15 C++对象模型和this指针
  • HarmonyOS/OpenHarmony元服务开发-卡片生命周期管理
  • 软件工程01
  • UML/SysML建模工具更新(2023.7)(1-5)有国产工具
  • Mac plist文件
  • 基于Java+SpringBoot+vue前后端分离校园周边美食探索分享平台设计实现
  • 【openwrt】package介绍