關於去重複問題

2022-01-17 08:50:10 字數 4159 閱讀 6568

person1: id=1, name="test1"

person2: id=1, name="test1"

person3: id=2, name="test2"

以上list如果直接使用distinct方法進行過濾,仍然返回3條資料,而需要的結果是2條資料。下面給出解這個問題的方法:

方法1:distinct 方法中使用的相等比較器。這個比較器需要重寫equals和gethashcode方法,個人不推薦,感覺較麻煩,需要些多餘的類,並且用起來還要例項化乙個比較器,當然自己也可以寫乙個泛型的比較器生成工廠用來專門生成比較器,但仍然覺得較麻煩。

msdn給出的做法,具體參照:

方法2:自己擴充套件乙個distinctby。這個擴充套件方法還是很不錯的,用起來很簡潔,適合為框架新增的distinct擴充套件方法。

publicstaticienumerabledistinctby(thisienumerablesource, funckeyselector)

}

}

使用方法如下(針對id,和name進行distinct):

varquery = people.distinctby(p =>new);

若僅僅針對id進行distinct:

varquery = people.distinctby(p => p.id);

方法3:通過groupby分組後,並取出第一條資料。簡單易用,很方便。這是一種迂迴策略,**理解起來沒有distinct表意清晰,雖然實現了效果。

listdistinctpeople = allpeople

.groupby(p =>new)

.select(g => g.first())

.tolist();

、、剛開始接觸linq時使用distinct去重時和大家一樣遇到了一些麻煩,很感謝  提供的一些方法。

後來經過深入學習,了解了一些更為簡潔的方法,在這裡與大家一同分享。

如上圖在webconfig表中含有以下三個欄位name,linkhref和type,現在我們要對type去重獲取所有型別。

第一種使用distinct方法:

viewbag.dist = db.webconfig.select(p => p.type).distinct().tolist();
使用這種方法篩選出來的是乙個string集合

前台展示:

第二種使用distinctby方法:

viewbag.dist1 = db.webconfig.distinctby(p => p.type).tolist();
使用這種方法篩選出來的是乙個model型別(webconfig)

前台展示:

第三種使用groupby方法:

viewbag.dist2 = db.webconfig.groupby(p => p.type).select(p=>p.key).tolist();
使用這種方法篩選出來的是乙個鍵值對()

前台展示:

person1: id=1, name="test1"person2: id=1, name="test1"person3: id=2, name="test2"

以上list如果直接使用distinct方法進行過濾,仍然返回3條資料,而需要的結果是2條資料。下面給出解這個問題的方法:

方法1:distinct 方法中使用的相等比較器。這個比較器需要重寫equals和gethashcode方法,個人不推薦,感覺較麻煩,需要些多餘的類,並且用起來還要例項化乙個比較器,當然自己也可以寫乙個泛型的比較器生成工廠用來專門生成比較器,但仍然覺得較麻煩。

msdn給出的做法,具體參照:

方法2:自己擴充套件乙個distinctby。這個擴充套件方法還是很不錯的,用起來很簡潔,適合為框架新增的distinct擴充套件方法。

publicstaticienumerabledistinctby(thisienumerablesource, funckeyselector)

}

}

使用方法如下(針對id,和name進行distinct):

varquery = people.distinctby(p =>new);

若僅僅針對id進行distinct:

varquery = people.distinctby(p => p.id);

方法3:通過groupby分組後,並取出第一條資料。簡單易用,很方便。這是一種迂迴策略,**理解起來沒有distinct表意清晰,雖然實現了效果。

listdistinctpeople = allpeople

.groupby(p =>new)

.select(g => g.first())

.tolist();

、、剛開始接觸linq時使用distinct去重時和大家一樣遇到了一些麻煩,很感謝  提供的一些方法。

後來經過深入學習,了解了一些更為簡潔的方法,在這裡與大家一同分享。

如上圖在webconfig表中含有以下三個欄位name,linkhref和type,現在我們要對type去重獲取所有型別。

第一種使用distinct方法:

viewbag.dist = db.webconfig.select(p => p.type).distinct().tolist();
使用這種方法篩選出來的是乙個string集合

前台展示:

第二種使用distinctby方法:

viewbag.dist1 = db.webconfig.distinctby(p => p.type).tolist();
使用這種方法篩選出來的是乙個model型別(webconfig)

前台展示:

第三種使用groupby方法:

viewbag.dist2 = db.webconfig.groupby(p => p.type).select(p=>p.key).tolist();
使用這種方法篩選出來的是乙個鍵值對()

前台展示:

陣列去重複

最近在寫demo的時候新學了一招 陣列去重複的方法 思路 利用json特性。1 建立乙個空json,通過對key的檢索 獲得json中 key 值 json arr i 2 對該值取反 json arr i 說明該值不存在。3 這樣我們可以對其賦值,json arr i true 這裡賦什麼值無所謂...

陣列去重複

1.開闢新的記憶體空間 判斷是否存在,若不存在則新增到陣列中,得到最終結果的順序不發生變化 nsarray originalarr 1,2,3,1,3 nsmutablearray resultarrm nsmutablearray array for nsstring item in origin...

js陣列去重複

1.遍歷陣列法 實現思路 新建乙個陣列,遍歷去要重的陣列,當值不在新陣列的時候 indexof為 1 就加入該新陣列中 var arr 2,8,5,0,5,2,6,7,2 function unique1 arr return hash 2.陣列下標判斷法 呼叫indexof方法,效能和方法1差不多...