C#中的Linq Intersect与Except方法使用实例

所属分类: 软件编程 / C#教程 阅读数: 167
收藏 0 赞 0 分享

实例描述

现有某班学生的两份成绩,两份成绩中存在一些不一致的记录。需借助于编程方法找出这些不一致的记录。

实例代码

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方法找出两份记录中不一致的记录,该方法同样使用传入的比较器对值进行比较决定记录是否相同。

执行结果

更多精彩内容其他人还在看

C#抽象类与抽象方法详解

这篇文章主要为大家详细介绍了C#抽象类与抽象方法的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

C#代码实现扑克牌排序的几种方式

今天小编就为大家分享一篇关于C#代码实现扑克牌排序,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
收藏 0 赞 0 分享

C#泛型概念的简介与泛型的使用

今天小编就为大家分享一篇关于C#泛型概念的简介与泛型的使用,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
收藏 0 赞 0 分享

C# 7.0 使用下划线忽略使用的变量的原因分析

这篇文章主要介绍了C# 7.0 使用下划线忽略使用的变量的原因浅析,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享

C# 中使用正则表达式匹配字符的含义

正则表达式的作用用来描述字符串的特征。本文重点给大家介绍C# 中使用正则表达式匹配字符的含义,非常不错,具有一定的参考借鉴价值,需要的朋友参考下吧
收藏 0 赞 0 分享

C# Dictionary和SortedDictionary的简介

今天小编就为大家分享一篇关于C# Dictionary和SortedDictionary的简介,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
收藏 0 赞 0 分享

C#中SQL Command的基本用法

今天小编就为大家分享一篇关于C#中SQL Command的基本用法,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
收藏 0 赞 0 分享

C#使用SQL DataReader访问数据的优点和实例

今天小编就为大家分享一篇关于C#使用SQL DataReader访问数据的优点和实例,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
收藏 0 赞 0 分享

C#使用SQL Dataset数据集代码实例

今天小编就为大家分享一篇关于的文章,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
收藏 0 赞 0 分享

C#使用SQL DataAdapter数据适配代码实例

今天小编就为大家分享一篇关于C#使用SQL DataAdapter数据适配代码实例,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
收藏 0 赞 0 分享
查看更多