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

相关推荐
沉淀粉条形变量2 分钟前
rust 单例模式
开发语言·单例模式·rust
光电笑映6 分钟前
C++11 新特性全解:语法糖、容器进化与可调用对象包装
开发语言·c++
派葛穆8 分钟前
汇川PLC-Unity3d与汇川easy521plc进行Modbustcp通讯
unity·c#
qq_白羊座8 分钟前
Langchain、Cursor、python的关系
开发语言·python·langchain
kiku181811 分钟前
Python网络编程
开发语言·网络·python
小李子呢021119 分钟前
前端八股3---ref和reactive
开发语言·前端·javascript
SWAGGY..19 分钟前
【C++初阶】:(7)STL简介
开发语言·c++
dog25025 分钟前
卡瓦列里积分赏析
开发语言·php
流星蝴蝶没有剑30 分钟前
CoPaw Agent 对接 Python 客户端开发指南:实现流式响应与实时打印
开发语言·python
咬_咬37 分钟前
go语言学习(数组与切片)
开发语言·学习·golang·数组·切片