C#中分组循环的做法

在我们平时的开发需求中,一定遇到过这样的场景,你需要对一个datatable数据进行分组循环,像这一类的需求应该如何完成呢?

举个例子:

在这里我们在if里面对dt中KOorder,HostName,WERKS来进行分组后循环,应该如何做呢:

c 复制代码
 var groupedData = dt.AsEnumerable()
                     .GroupBy(dr => new {
                         KOorder = dr.Field<string>("KOorder"),
                         HostName = dr.Field<string>("HostName"),
                         WERKS = dr.Field<string>("WERKS")
                     })
                     .ToList();

 foreach (var group in groupedData)

这段代码中核心点在于groupedData 的赋值问题,在这里我们借助LINQ对dt进行分组数据的转换,

AsEnumerable(): 将DataTable转换为可LINQ操作的IEnumerable

GroupBy: 按三个字段组合创建分组键(匿名类型)

KOorder: 字符串类型的KOorder列值

HostName: 字符串类型的HostName列值

WERKS: 字符串类型的WERKS列值(通常是SAP系统中的工厂代码)

ToList(): 立即执行查询并将分组结果转换为内存中的List<IGrouping<...>>

那么就会转换为类List的分组数据,进行foreach即可完成需求

相关推荐
jmlinux17 分钟前
从 C 语言计算器到串口屏应用
c语言·开发语言
Mallow Flowers1 小时前
Python训练营-Day31-文件的拆分和使用
开发语言·人工智能·python·算法·机器学习
云边小网安1 小时前
java集合篇(六) ---- ListIterator 接口
java·开发语言·青少年编程·java集合
不被定义的程序猿2 小时前
Golang 在 Linux 平台上的并发控制
开发语言·后端·golang
陈旭金-小金子2 小时前
发现 Kotlin MultiPlatform 的一点小变化
android·开发语言·kotlin
Mikhail_G2 小时前
Python应用八股文
大数据·运维·开发语言·python·数据分析
景彡先生3 小时前
C++ 中文件 IO 操作详解
开发语言·c++
董先生_ad986ad3 小时前
C# 解析 URL URI 中的参数
前端·c#
你怎么知道我是队长3 小时前
GO语言---defer关键字
开发语言·后端·golang
无影无踪的青蛙3 小时前
[C++] STL大家族之<map>(字典)容器(附洛谷)
开发语言·c++