C#中去重的高級方法,你了解幾個?
當前位置:點晴教程→知識管理交流
→『 技術文檔交流 』
今天我們一起來討論一下關于C#數據去重的常見的幾種方式,每種方法都有其特點和適用場景,我們根據具體需求選擇最合適的方式。當然歡迎你在評論區留下你覺得更好的數據去重的方式。以下是一些常見的方法: 1、使用DISTINCT關鍵字: 在SQL查詢中,可以使用DISTINCT關鍵字來刪除重復的行。在C#中,可以使用LINQ和SqlCommand對象來執行類似的查詢。例如: 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()) { // 處理結果 } } } } 2、使用HashSet: HashSet是一個不包含重復元素的集合。可以使用它來快速查找和刪除重復項。例如: 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); 在這個例子中,result列表只包含不重復的數字。 3、使用LINQ: LINQ是C#中強大的查詢語法,可以用于過濾、排序和組合數據集。使用LINQ,可以非常容易地刪除重復項。例如: List<int> numbers = new List<int> { 1, 2, 3, 4, 4, 5, 5, 6 }; var uniqueNumbers = numbers.Distinct().ToList(); 這個例子使用LINQ的Distinct方法來刪除重復的數字。 4、使用Linq的GroupBy()方法去重 GroupBy()方法將原始集合中的元素進行分組,根據指定的鍵或條件進行分組。每個分組都會有一個唯一的鍵,通過將原始集合分組并選擇每個分組中的第一個元素,實現了去重的效果。 /// <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()方法將原始集合中的元素進行分組,根據指定的鍵或條件進行分組。每個分組都會有一個唯一的鍵,通過將原始集合分組并選擇每個分組中的第一個元素,實現了去重的效果。 var uniqueData = dataSource.GroupBy(item => item).select(group => group.First()).ToList(); Console.WriteLine(string.Join(", ", uniqueData)); } 5、使用自定義的比較器和循環遍歷
public class ArrayDeduplication { /// <summary> /// 使用自定義的比較器和循環遍歷 /// </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、直接循環遍歷去重 /// <summary> /// 直接循環遍歷去重 /// </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 編輯過 |
關鍵字查詢
相關文章
正在查詢... |