当前位置:
首页 > Python基础教程 >
-
C#教程之C#中的Linq Intersect与Except方法使用实例
实例描述
现有某班学生的两份成绩,两份成绩中存在一些不一致的记录。需借助于编程方法找出这些不一致的记录。
实例代码
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方法找出两份记录中不一致的记录,该方法同样使用传入的比较器对值进行比较决定记录是否相同。
执行结果
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式