热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

[C#]使用Join与GroupJoin将两个集合进行关联与分组

本文为原创文章、源代码为原创代码,如转载复制,请在网页代码处明显位置标明原文名称、作者及网址,谢谢!本文使用的开发环境是VS2017及dotNet4.0,写此随笔的目的是给自己及新开发

本文为原创文章、源代码为原创代码,如转载/复制,请在网页/代码处明显位置标明原文名称、作者及网址,谢谢!


本文使用的开发环境是VS2017及dotNet4.0,写此随笔的目的是给自己及新开发人员作为参考,

 

对于Join的用法说明如下:

语法:

public static IEnumerable Join(
    this IEnumerable outer,
    IEnumerable inner,
    Func outerKeySelector,
    Func innerKeySelector,
    Func resultSelector
)

参数说明:

outer
Type: System.Collections.Generic.IEnumerable
要联接的第一个序列。
inner
Type: System.Collections.Generic.IEnumerable
要与第一个序列联接的序列。
outerKeySelector
Type: System.Func
用于从第一个序列的每个元素提取联接键的函数。
innerKeySelector
Type: System.Func
用于从第二个序列的每个元素提取联接键的函数。
resultSelector
Type: System.Func
用于从两个匹配元素创建结果元素的函数。
返回值
Type: System.Collections.Generic.IEnumerable
IEnumerable ,其类型的元素 TResult 通过对两个序列执行内部联接获得的。

参数类型:

TOuter
第一个序列中的元素的类型。
TInner
第二个序列中的元素的类型。
TKey
键选择器函数返回的键的类型。
TResult
结果元素的类型。

参考链接如下:

https://msdn.microsoft.com/zh-cn/library/bb534675.aspx
https://docs.microsoft.com/zh-cn/dotnet/api/system.linq.enumerable.join?f1url=https%3A%2F%2Fmsdn.microsoft.com%2Fquery%2Fdev15.query%3FappId%3DDev15IDEF1%26l%3DZH-CN%26k%3Dk(System.Linq.Enumerable.Join%60%604);k(TargetFrameworkMoniker-.NETFramework,Version%3Dv4.0);k(DevLang-csharp)%26rd%3Dtrue&view=netframework-4.7.1

例程:

using System;
using System.Collections.Generic;
using System.Linq;

namespace ConsoleApp33
{
    class Program
    {
        static void Main(string[] args)
        {
            GroupJoinEx();
        }

        static void GroupJoinEx()
        {
            Person p1 = new Person() { Name = "ABC", Age = 18 };
            Person p2 = new Person() { Name = "EFG", Age = 19 };
            Person p3 = new Person() { Name = "LMN", Age = 20 };
            Person p4 = new Person() { Name = "XYZ", Age = 21 };

            List pList = new List { p1, p2, p3, p4 };

            Department d1 = new Department() { Name = "A1", Employee = p1 };
            Department d2 = new Department() { Name = "A2", Employee = p2 };
            Department d3 = new Department() { Name = "A3", Employee = p1 };
            Department d4 = new Department() { Name = "B1", Employee = p3 };
            Department d5 = new Department() { Name = "B2", Employee = p4 };
            Department d6 = new Department() { Name = "B3", Employee = p4 };

            List dList = new List { d1, d2, d3, d4, d5, d6 };

            var result = pList.Join(dList,
                person => person,
                department => department.Employee,
                (person, department) => new
                {
                    Person = person,
                    Department = department
                });

            foreach(var item1 in result)
            {
                Console.Write($"Name:{item1.Person} & Department:{item1.Department} ");
                Console.WriteLine();
            }
        }
    }

    class Person
    {
        public string Name { set; get; }
        public int Age { set; get; }
        public override string ToString()
        {
            return $"{Name},{Age}";
        }
    }

    class Department
    {
        public string Name { set; get; }
        public Person Employee { set; get; }
        public override string ToString()
        {
            return $"{Name}";
        }
    }
}

输出结果:

 

对于GroupJoin的用法说明如下:

语法:

public static IEnumerable GroupJoin(
    this IEnumerable outer,
    IEnumerable inner,
    Func outerKeySelector,
    Func innerKeySelector,
    Func, TResult> resultSelector
)

参数说明:

outer
Type: System.Collections.Generic.IEnumerable
要联接的第一个序列。
inner
Type: System.Collections.Generic.IEnumerable
要与第一个序列联接的序列。
outerKeySelector
Type: System.Func
用于从第一个序列的每个元素提取联接键的函数。
innerKeySelector
Type: System.Func
用于从第二个序列的每个元素提取联接键的函数。
resultSelector
Type: System.Func, TResult>
用于从第一个序列的元素和第二个序列的匹配元素集合中创建结果元素的函数。
返回值
Type: System.Collections.Generic.IEnumerable<TResult>
IEnumerable ,其中包含类型的元素 TResult 通过对两个序列执行分组的联接获得的。

参数类型:

TOuter
第一个序列中的元素的类型。
TInner
第二个序列中的元素的类型。
TKey
键选择器函数返回的键的类型。
TResult
结果元素的类型。

参考链接如下:

https://msdn.microsoft.com/zh-cn/library/bb534297.aspx
https://docs.microsoft.com/zh-cn/dotnet/api/system.linq.enumerable.groupjoin?f1url=https%3A%2F%2Fmsdn.microsoft.com%2Fquery%2Fdev15.query%3FappId%3DDev15IDEF1%26l%3DZH-CN%26k%3Dk(System.Linq.Enumerable.GroupJoin%60%604);k(TargetFrameworkMoniker-.NETFramework,Version%3Dv4.0);k(DevLang-csharp)%26rd%3Dtrue&view=netframework-4.7.1

例程:

using System;
using System.Collections.Generic;
using System.Linq;

namespace ConsoleApp33
{
    class Program
    {
        static void Main(string[] args)
        {
            GroupJoinEx();
        }

        static void GroupJoinEx()
        {
            Person p1 = new Person() { Name = "ABC", Age = 18 };
            Person p2 = new Person() { Name = "EFG", Age = 19 };
            Person p3 = new Person() { Name = "LMN", Age = 20 };
            Person p4 = new Person() { Name = "XYZ", Age = 21 };

            List pList = new List { p1, p2, p3, p4 };

            Department d1 = new Department() { Name = "A1", Employee = p1 };
            Department d2 = new Department() { Name = "A2", Employee = p2 };
            Department d3 = new Department() { Name = "A3", Employee = p1 };
            Department d4 = new Department() { Name = "B1", Employee = p3 };
            Department d5 = new Department() { Name = "B2", Employee = p4 };
            Department d6 = new Department() { Name = "B3", Employee = p4 };

            List dList = new List { d1, d2, d3, d4, d5, d6 };

            var result = pList.GroupJoin(dList,
                person => person,
                department => department.Employee,
                (person, departments) => new
                {
                    Person = person,
                    Department = departments.Select(d => d)
                });

            foreach(var item1 in result)
            {
                Console.Write($"Name:{item1.Person} & "); foreach(var item2 in item1.Department) { if(item1.Department.First() == item2) Console.Write($"Department:{item2} "); else Console.Write($"{item2} "); }
                Console.WriteLine();
            }
        }
    }

    class Person
    {
        public string Name { set; get; }
        public int Age { set; get; }
        public override string ToString()
        {
            return $"{Name},{Age}";
        }
    }

    class Department
    {
        public string Name { set; get; }
        public Person Employee { set; get; }
        public override string ToString()
        {
            return $"{Name}";
        }
    }
}

输出结果:

以上代码仅在Join与GroupJoin最后一个参数有区别,可以参见红色字体部分,

并从以上结果来看,Join与GroupJoin的区别一个在于:Join仅仅是将两个结合进行关联,而GroupJoin则会进行分组。

 


推荐阅读
  • 使用nodejs爬取b站番剧数据,计算最佳追番推荐
    本文介绍了如何使用nodejs爬取b站番剧数据,并通过计算得出最佳追番推荐。通过调用相关接口获取番剧数据和评分数据,以及使用相应的算法进行计算。该方法可以帮助用户找到适合自己的番剧进行观看。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • SpringBoot uri统一权限管理的实现方法及步骤详解
    本文详细介绍了SpringBoot中实现uri统一权限管理的方法,包括表结构定义、自动统计URI并自动删除脏数据、程序启动加载等步骤。通过该方法可以提高系统的安全性,实现对系统任意接口的权限拦截验证。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文详细介绍了Spring的JdbcTemplate的使用方法,包括执行存储过程、存储函数的call()方法,执行任何SQL语句的execute()方法,单个更新和批量更新的update()和batchUpdate()方法,以及单查和列表查询的query()和queryForXXX()方法。提供了经过测试的API供使用。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • 微软头条实习生分享深度学习自学指南
    本文介绍了一位微软头条实习生自学深度学习的经验分享,包括学习资源推荐、重要基础知识的学习要点等。作者强调了学好Python和数学基础的重要性,并提供了一些建议。 ... [详细]
  • JavaSE笔试题-接口、抽象类、多态等问题解答
    本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • Google Play推出全新的应用内评价API,帮助开发者获取更多优质用户反馈。用户每天在Google Play上发表数百万条评论,这有助于开发者了解用户喜好和改进需求。开发者可以选择在适当的时间请求用户撰写评论,以获得全面而有用的反馈。全新应用内评价功能让用户无需返回应用详情页面即可发表评论,提升用户体验。 ... [详细]
  • CF:3D City Model(小思维)问题解析和代码实现
    本文通过解析CF:3D City Model问题,介绍了问题的背景和要求,并给出了相应的代码实现。该问题涉及到在一个矩形的网格上建造城市的情景,每个网格单元可以作为建筑的基础,建筑由多个立方体叠加而成。文章详细讲解了问题的解决思路,并给出了相应的代码实现供读者参考。 ... [详细]
  • 有没有一种方法可以在不继承UIAlertController的子类或不涉及UIAlertActions的情况下 ... [详细]
author-avatar
Paul_Zhao
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有