C#之List集合去重復(fù)對象的實(shí)現(xiàn)方法
C# List集合去重復(fù)對象方法
1、測試數(shù)據(jù)
List<string> str_list = new List<string> { "1", "2", "3", "3" ,"4","5","5"};
簡單List去重
var distinctList = str_list.Distinct();
2、測試數(shù)據(jù)
var RegInfoList= new List<RegInfo> { new RegInfo { Id=A1001, Name="test1",Desc="阿莫西林"}, new RegInfo { Id=A1001, Name="test1",Desc="阿莫西林" }, new RegInfo { Id=A1002, Name="test2",Desc="葡萄糖注射液"}, new RegInfo { Id=B1003, Name="test3",Desc="氯化鈉注射液"}, new RegInfo { Id=C1002, Name="test4",Desc="嗎丁啉"} };
2.1多屬性去重(根據(jù)Id,Name進(jìn)行Distinct)
List<RegInfo> distinctRegInfo = RegInfoList .GroupBy(p => new {p.Id, p.Name} ) .Select(g => g.First()) .ToList();
2.2單屬性去重(根據(jù)Id進(jìn)行Distinct)
var distinctList = RegInfoList.GroupBy(x => x.Id).Select(y => y.First()); var distinctList = RegInfoList.GroupBy(x => x.Id).Select(y => y.FirstOrDefault());
3、知識點(diǎn)補(bǔ)充
3.1 Linq First 和 FirstOrDefault的區(qū)別
First() 方法
- 返回序列中的第一個(gè)元素。
FirstOrDefault ()方法
- 返回序列中的第一個(gè)元素;如果序列中不包含任何元素,則返回默認(rèn)值 null。
注:
如果返回的是對象, 建議使用FirstOrDefault ,并對返回的對象進(jìn)行判空操作
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
基于Unity實(shí)現(xiàn)3D版2048游戲的示例代碼
這篇文章主要為大家詳細(xì)介紹了如何利用Unity實(shí)現(xiàn)簡易的3D版2048游戲,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,需要的可以參考一下2023-02-02visio二次開發(fā)--判斷文檔是否已發(fā)生變化(變化就加星號*)
最近做一個(gè)故障樹診斷的項(xiàng)目,用visio二次開發(fā),可以同時(shí)打開多個(gè)繪制的故障樹圖形文檔。項(xiàng)目中需要實(shí)現(xiàn)判斷文檔是否發(fā)生變化,這是很多編輯軟件的基本功能,變化了就加個(gè)星號*2013-04-04UnityShader使用圖像疊加實(shí)現(xiàn)運(yùn)動模糊
這篇文章主要為大家詳細(xì)介紹了UnityShader使用圖像疊加實(shí)現(xiàn)運(yùn)動模糊,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-02-02C#簡單實(shí)現(xiàn)防止多個(gè)程序運(yùn)行的方法
這篇文章主要介紹了C#簡單實(shí)現(xiàn)防止多個(gè)程序運(yùn)行的方法,涉及C#進(jìn)程操作的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2016-02-02C#拼接SQL語句 用ROW_NUMBER實(shí)現(xiàn)的高效分頁排序
C#拼接SQL語句,SQL Server 2005+,多行多列大數(shù)據(jù)量情況下,使用ROW_NUMBER實(shí)現(xiàn)的高效分頁排序2012-05-05