C#之linq和lamda表达式GroupBy分组拼接字符串

文章目录

C#之linq和lamda表达式GroupBy分组拼接字符串

业务需求

点击提示信息,如:"售后单【SH001】序列号【001,002,006】;售后单【SH002】序列号【003,007,009】。已经过了质保期,确认要继续关闭吗"

核心代码

csharp 复制代码
 //lamda表达式
 var errorMsgObj = getNoPay.GroupBy(s => s["FBILLNO"] + "")
                            .Select(d=>new { 
                                BillNo=d.Key,
                                NumberList=string.Join(",",d.Select(f=>f["FNUMBER"]+""))
                            }).ToList();


//Linq
var resultMsg = (from item in getNoPay
                    group item by item["FBILLNO"] into g
                    let numbers = g.Select(b => b["FNUMBER"]).ToArray()
                    select new
                    {
                        BillNo = g.Key,
                        NumberList = string.Join(",", numbers)
                    }).ToList();

调试

集合数据:

展示数据:

相关推荐
维度攻城狮2 小时前
ros2参数通信案例
开发语言·windows·python·ros2·参数通信
清水白石0082 小时前
Python 与尾递归:为何不优化?如何优雅绕过?
开发语言·python
王大傻09282 小时前
使用python for循环与ord() + chr()实现字符串加密
开发语言·python
Louis Maos2 小时前
堆与栈分配的本质区别
java·开发语言
毕设源码-朱学姐3 小时前
【开题答辩全过程】以 果蔬禽蛋生鲜食品采购配送系统的设计与实现为例,包含答辩的问题和答案
java·开发语言
不要em0啦3 小时前
从0开始学python:函数与数据容器
开发语言·python
zfj3213 小时前
java线程的不同状态下调用interrupt()方法后的行为及注意事项
java·开发语言·interrupt·线程中断·线程状态
XLYcmy3 小时前
高级密码猜测生成器AdvancedPasswordGenerator密码生成器程序详细分析
开发语言·python·算法·网络安全·开发工具·源代码·口令安全
廋到被风吹走4 小时前
【Java】【Jdk】Jdk17->Jdk21
java·开发语言
2201_761199044 小时前
7.statefulset
开发语言·kubernetes·php