C#中去重的高級(jí)方法,你了解幾個(gè)?
當(dāng)前位置:點(diǎn)晴教程→知識(shí)管理交流
→『 技術(shù)文檔交流 』
今天我們一起來(lái)討論一下關(guān)于C#數(shù)據(jù)去重的常見(jiàn)的幾種方式,每種方法都有其特點(diǎn)和適用場(chǎng)景,我們根據(jù)具體需求選擇最合適的方式。當(dāng)然歡迎你在評(píng)論區(qū)留下你覺(jué)得更好的數(shù)據(jù)去重的方式。以下是一些常見(jiàn)的方法: 1、使用DISTINCT關(guān)鍵字: 在SQL查詢(xún)中,可以使用DISTINCT關(guān)鍵字來(lái)刪除重復(fù)的行。在C#中,可以使用LINQ和SqlCommand對(duì)象來(lái)執(zhí)行類(lèi)似的查詢(xún)。例如: string connString = "Your Connection String"; using (SqlConnection conn = new SqlConnection(connString)){ conn.Open(); string sql = "select DISTINCT column1, column2 from your_table"; using (SqlCommand cmd = new SqlCommand(sql, conn)) { using (SqlDataReader reader = cmd.executeReader()) { while (reader.Read()) { // 處理結(jié)果 } } } } 2、使用HashSet: HashSet是一個(gè)不包含重復(fù)元素的集合??梢允褂盟鼇?lái)快速查找和刪除重復(fù)項(xiàng)。例如: List<int> numbers = new List<int> { 1, 2, 3, 4, 4, 5, 5, 6 }; HashSet<int> uniqueNumbers = new HashSet<int>(numbers); List<int> result = new List<int>(uniqueNumbers); 在這個(gè)例子中,result列表只包含不重復(fù)的數(shù)字。 3、使用LINQ: LINQ是C#中強(qiáng)大的查詢(xún)語(yǔ)法,可以用于過(guò)濾、排序和組合數(shù)據(jù)集。使用LINQ,可以非常容易地刪除重復(fù)項(xiàng)。例如: List<int> numbers = new List<int> { 1, 2, 3, 4, 4, 5, 5, 6 }; var uniqueNumbers = numbers.Distinct().ToList(); 這個(gè)例子使用LINQ的Distinct方法來(lái)刪除重復(fù)的數(shù)字。 4、使用Linq的GroupBy()方法去重 GroupBy()方法將原始集合中的元素進(jìn)行分組,根據(jù)指定的鍵或條件進(jìn)行分組。每個(gè)分組都會(huì)有一個(gè)唯一的鍵,通過(guò)將原始集合分組并選擇每個(gè)分組中的第一個(gè)元素,實(shí)現(xiàn)了去重的效果。 /// <summary> /// 使用Linq的GroupBy()方法去重 /// </summary> public static void GroupByDuplicate() { var dataSource = new List<int>() { 1, 2, 3, 2, 5, 88, 99, 99, 100, 88, 30, 50, 15, 100, 99, 99, 2, 3 }; //GroupBy()方法將原始集合中的元素進(jìn)行分組,根據(jù)指定的鍵或條件進(jìn)行分組。每個(gè)分組都會(huì)有一個(gè)唯一的鍵,通過(guò)將原始集合分組并選擇每個(gè)分組中的第一個(gè)元素,實(shí)現(xiàn)了去重的效果。 var uniqueData = dataSource.GroupBy(item => item).select(group => group.First()).ToList(); Console.WriteLine(string.Join(", ", uniqueData)); } 5、使用自定義的比較器和循環(huán)遍歷
public class ArrayDeduplication { /// <summary> /// 使用自定義的比較器和循環(huán)遍歷 /// </summary> public static void CustomEqualityComparerDuplicate(){ var dataSource = new List<int>() { 1, 2, 3, 2, 5, 88, 99, 99, 100, 88, 30, 50, 15, 100, 99, 99, 2, 3 }; var uniqueData = new List<int>(); foreach (var item in dataSource) { if (!uniqueData.Contains(item, new CustomEqualityComparer())) { uniqueData.Add(item); } } Console.WriteLine(string.Join(", ", uniqueData)); } } /// <summary> /// 自定義的比較器 /// </summary> public class CustomEqualityComparer : IEqualityComparer<int> { public bool Equals(int x, int y){ return x == y; } public int GetHashCode(int obj){ return obj.GetHashCode(); } } 6、直接循環(huán)遍歷去重 /// <summary> /// 直接循環(huán)遍歷去重 /// </summary> public static void LoopTraversalDuplicate() { var dataSource = new List<int>() { 1, 2, 3, 2, 5, 88, 99, 99, 100, 88, 30, 50, 15, 100, 99, 99, 2, 3 }; var uniqueData = new List<int>(); foreach (var item in dataSource) { //if (!uniqueData.Any(x => x == item)) //if (!uniqueData.Exists(x => x == item)) if (!uniqueData.Contains(item)) { uniqueData.Add(item); } } Console.WriteLine(string.Join(", ", uniqueData)); } 該文章在 2023/10/10 10:30:21 編輯過(guò) |
關(guān)鍵字查詢(xún)
相關(guān)文章
正在查詢(xún)... |