English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

LINQ Set 연산자 Except

Except() 메서드는 두 개의 셋이 필요합니다. 첫 번째 셋에서 두 번째 셋(인자 셋)에 존재하지 않는 요소를 포함한 새로운 셋을 반환합니다.

IList<string> strList1 = new List<string>{"One", "Two", "Three", "Four", "Five"};
IList<string> strList2 = new List<string>{"Four", "Five", "Six", "Seven", "Eight"};
var result = strList1.Except(strList2);
foreach (string str in result)
        Console.WriteLine(str);
출력:
One
Two
Three

Except 확장 메서드는 복잡한 유형의 셋을 올바른 결과로 반환하지 않습니다. Except 메서드에서 올바른 결과를 얻으려면 IEqualityComparer 인터페이스를 구현해야 합니다.

Student 클래스에 IEqualityComparer 인터페이스를 구현하면 다음과 같습니다:

예제: C#에서 Except 메서드를 사용한 IEqualityComparer
public class Student 
{
    public int StudentID { get; set; }
    public string StudentName { get; set; }
    public int Age { get; set; }
}
class StudentComparer : IEqualityComparer<Student>
{
    public bool Equals(Student x, Student y)
    {
        if (x.StudentID == y.StudentID && x.StudentName.ToLower() == y.StudentName.ToLower())
            return true;
        return false;
    }
    public int GetHashCode(Student obj)
    {
        return obj.StudentID.GetHashCode();
    }
}

현재, StudentComparer 클래스를 통해 Except 확장 메서드에서 올바른 결과를 얻을 수 있습니다:

예제: C# 객체 타입의 Except() 메서드
IList<Student> studentList1 = new List<Student>() { 
        new Student() { StudentID = 1, StudentName = "John",    Age = 18 },
        new Student() { StudentID = 2, StudentName = "Steve",    Age = 15 },
        new Student() { StudentID = 3, StudentName = "Bill",    Age = 25 },
        new Student() { StudentID = 5, StudentName = "Ron" , Age = 19 } 
    };
IList<Student> studentList2 = new List<Student>() { 
        new Student() { StudentID = 3, StudentName = "Bill",    Age = 25 },
        new Student() { StudentID = 5, StudentName = "Ron" , Age = 19 } 
    };
var resultedCol = studentList1.Except(studentList2,new StudentComparer()); 
foreach(Student std in resultedCol)
    Console.WriteLine(std.StudentName);
출력:
John
Steve

C # & VB.Net 쿼리 문법은 Except 연산자를 지원하지 않습니다. 그러나, 쿼리 변수에 Distinct 메서드를 사용하거나, 전체 쿼리를 괄호로 감싸고 Except ()를 호출할 수 있습니다.