使用Linq的Intersect与Except方法的实例
来源:互联网 发布:绘图软件上色教学 编辑:程序博客网 时间:2024/06/05 09:01
实例描述
现有某班学生的两份成绩,两份成绩中存在一些不一致的记录。需借助于编程方法找出这些不一致的记录。
实例代码
using System;using System.Collections.Generic;using System.Linq;namespace IntersectAndExceptExp{ class Program { static void Main(string[] args) { List<Student> studentList1 = newList<Student>() { new Student(){StudentId=1,Score=64}, new Student(){StudentId=2,Score=85}, new Student(){StudentId=3,Score=78}, new Student(){StudentId=4,Score=94}, new Student(){StudentId=5,Score=90} }; List<Student> studentList2 = newList<Student>() { new Student(){StudentId=1,Score=64}, new Student(){StudentId=2,Score=80}, new Student(){StudentId=3,Score=78}, new Student(){StudentId=4,Score=94}, new Student(){StudentId=5,Score=95} }; var both = studentList1.Intersect(studentList2,new StudentComparer()); var diff1 =studentList1.Except(both, new StudentComparer()); var diff2 =studentList2.Except(both, new StudentComparer()); Console.WriteLine("-------------下面是两份成绩中不同的记录--------------"); Console.WriteLine("-------------第一份学生成绩--------------"); foreach (var s in diff1) { Console.WriteLine("StudentId:"+s.StudentId+";Score:"+s.Score); } Console.WriteLine("-------------第一份学生成绩--------------"); foreach (var s in diff2) { Console.WriteLine("StudentId:"+ s.StudentId + ";Score:" + s.Score); } } } public class Student { public int StudentId { get; set; } public int Score { get; set; } } public class StudentComparer : IEqualityComparer<Student> { public bool Equals(Student x, Studenty) { if (Object.ReferenceEquals(x, y)) returntrue; return x != null && y != null&& x.StudentId == y.StudentId && x.Score == y.Score; } public int GetHashCode(Student obj) { int hashStudentId =obj.StudentId.GetHashCode(); int hashScore =obj.Score.GetHashCode(); return hashStudentId ^ hashScore; } }}
代码说明
先使用Intersect方法生成两份记录的交集,该方法会使用传入的比较器对值进行比较决定记录是否相同。基于前步生成的交集,再使用Except方法找出两份记录中不一致的记录,该方法同样使用传入的比较器对值进行比较决定记录是否相同。
执行结果
0 0
- 使用Linq的Intersect与Except方法的实例
- 使用Linq的Intersect与Except方法的实例
- SQL SERVER 2008的EXCEPT和INTERSECT
- SQL中Union,Intersect,Except的区别
- sql里面EXCEPT、INTERSECT的区别
- LINQ to SQL语句 Union/Intersect/Except
- MySQL不支持FULL JOIN, INTERSECT和MINUS(except)的替代方法
- 关于SQL2000的交并差(Intersect、Union、Except)命令说明
- SQL Server 2005中Except和Intersect的用法示例
- SQL Server 中关于EXCEPT和INTERSECT的用法
- SQL Server 中关于EXCEPT和INTERSECT的用法
- 探讨 T-SQL 的 EXISTS、EXCEPT、INTERSECT 算符
- SQL Server 中关于EXCEPT和INTERSECT的用法
- SQL Server 中关于EXCEPT和INTERSECT的用法
- SQL Server 中关于EXCEPT和INTERSECT的用法
- SQL Server 中关于EXCEPT和INTERSECT的用法
- 探讨 T-SQL 的 EXISTS、EXCEPT、INTERSECT 算符
- SQL Server 中关于EXCEPT和INTERSECT的用法
- ViewHolder的简洁写法
- android:layout_weight为0
- Spring Mvc Demo遇到的问题
- 黑马程序员-Java面向对象III(面向对象相关问题及案例分析)
- qt5中文乱码
- 使用Linq的Intersect与Except方法的实例
- 递归目录合并或删除文件
- Android自定义View onMeasure
- 断言
- 获取网页状态
- java-导出excel并解决乱码问题
- open fdopen fread fwrite使用方法
- fib 斐波那契数列生成器
- 快速排序