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 编辑过 |
关键字查询
相关文章
正在查询... |