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即可完成需求

相关推荐
氵文大师22 分钟前
A机通过 python -m http.server 下载B机的文件
linux·开发语言·python·http
封奚泽优34 分钟前
下降算法(Python实现)
开发语言·python·算法
笃行客从不躺平1 小时前
遇到大SQL怎么处理
java·开发语言·数据库·sql
郝学胜-神的一滴1 小时前
Python中常见的内置类型
开发语言·python·程序人生·个人开发
g***B7381 小时前
Kotlin协程在Android中的使用
android·开发语言·kotlin
火白学安全1 小时前
《Python红队攻防零基础脚本编写:进阶篇(一)》
开发语言·python·安全·web安全·网络安全·系统安全
光头闪亮亮1 小时前
电子发票解析工具-c#桌面应用开发-DataGridView表格控件使用详解
c#
爱码小白1 小时前
PyQt5 QTimer总结
开发语言·qt
A***27952 小时前
Kotlin反射机制
android·开发语言·kotlin
E***q5392 小时前
C++内存对齐优化
开发语言·c++