C#中使用Join與GroupJoin將兩個集合進行關聯與分組
本文使用的開發(fā)環(huán)境是VS2017及dotNet4.0,寫此隨筆的目的是給自己及新開發(fā)人員作為參考,
對于Join的用法說明如下:
語法:
public static IEnumerable<TResult> Join<TOuter, TInner, TKey, TResult>( this IEnumerable<TOuter> outer, IEnumerable<TInner> inner, Func<TOuter, TKey> outerKeySelector, Func<TInner, TKey> innerKeySelector, Func<TOuter, TInner, TResult> resultSelector )
參數說明:
outer Type: System.Collections.Generic.IEnumerable<TOuter> 要聯接的第一個序列。 inner Type: System.Collections.Generic.IEnumerable<TInner> 要與第一個序列聯接的序列。 outerKeySelector Type: System.Func<TOuter, TKey> 用于從第一個序列的每個元素提取聯接鍵的函數。 innerKeySelector Type: System.Func<TInner, TKey> 用于從第二個序列的每個元素提取聯接鍵的函數。 resultSelector Type: System.Func<TOuter, TInner, TResult> 用于從兩個匹配元素創(chuàng)建結果元素的函數。 返回值 Type: System.Collections.Generic.IEnumerable<TResult> IEnumerable<T> ,其類型的元素 TResult 通過對兩個序列執(zhí)行內部聯接獲得的。
參數類型:
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<Person> pList = new List<Person> { 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<Department> dList = new List<Department> { 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<TResult> GroupJoin<TOuter, TInner, TKey, TResult>( this IEnumerable<TOuter> outer, IEnumerable<TInner> inner, Func<TOuter, TKey> outerKeySelector, Func<TInner, TKey> innerKeySelector, Func<TOuter, IEnumerable<TInner>, TResult> resultSelector )
參數說明:
outer Type: System.Collections.Generic.IEnumerable<TOuter>
要聯接的第一個序列。
inner Type: System.Collections.Generic.IEnumerable<TInner>
要與第一個序列聯接的序列。
outerKeySelector Type: System.Func<TOuter, TKey>
用于從第一個序列的每個元素提取聯接鍵的函數。
innerKeySelector Type: System.Func<TInner, TKey>
用于從第二個序列的每個元素提取聯接鍵的函數。
resultSelector Type: System.Func<TOuter, IEnumerable<TInner>, TResult>
用于從第一個序列的元素和第二個序列的匹配元素集合中創(chuàng)建結果元素的函數。
返回值
Type: System.Collections.Generic.IEnumerable<TResult> IEnumerable<T> ,其中包含類型的元素 TResult 通過對兩個序列執(zhí)行分組的聯接獲得的。
參數類型:
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<Person> pList = new List<Person> { 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<Department> dList = new List<Department> { 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最后一個參數有區(qū)別,可以參見紅色字體部分,
并從以上結果來看,Join與GroupJoin的區(qū)別一個在于:Join僅僅是將兩個結合進行關聯,而GroupJoin則會進行分組。
總結
以上所述是小編給大家介紹的C#中使用Join與GroupJoin將兩個集合進行關聯與分組,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對我們網站的支持!
欄 目:C#教程
下一篇:C#中字符串優(yōu)化String.Intern、IsInterned詳解
本文標題:C#中使用Join與GroupJoin將兩個集合進行關聯與分組
本文地址:http://www.jygsgssxh.com/a1/C_jiaocheng/5355.html
您可能感興趣的文章
- 01-10C#通過反射獲取當前工程中所有窗體并打開的方法
- 01-10C#實現Winform中打開網頁頁面的方法
- 01-10C#實現由四周向中心縮小的窗體退出特效
- 01-10Extjs4如何處理后臺json數據中日期和時間
- 01-10C#使用Dispose模式實現手動對資源的釋放
- 01-10C#3.0使用EventLog類寫Windows事件日志的方法
- 01-10C#中DataGridView常用操作實例小結
- 01-10C#編程獲取資源文件中圖片的方法
- 01-10C#使用windows服務開啟應用程序的方法
- 01-10asp.net中XML如何做增刪改查操作


閱讀排行
本欄相關
- 01-10C#通過反射獲取當前工程中所有窗體并
- 01-10關于ASP網頁無法打開的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#實現txt定位指定行完整實例
- 01-10WinForm實現仿視頻播放器左下角滾動新
- 01-10C#停止線程的方法
- 01-10C#實現清空回收站的方法
- 01-10C#通過重寫Panel改變邊框顏色與寬度的
- 01-10C#實現讀取注冊表監(jiān)控當前操作系統(tǒng)已
隨機閱讀
- 01-10C#中split用法實例總結
- 01-10delphi制作wav文件的方法
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10SublimeText編譯C開發(fā)環(huán)境設置
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-11ajax實現頁面的局部加載
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 04-02jquery與jsp,用jquery
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 08-05dedecms(織夢)副欄目數量限制代碼修改


