programing

C#에서 2 List를 병합하고 중복된 값을 제거하는 방법

abcjava 2023. 4. 26. 22:50
반응형

C#에서 2 List를 병합하고 중복된 값을 제거하는 방법

두 개의 목록이 있습니다. 세 번째 목록에서 결합하고 해당 목록에서 중복 값을 제거해야 합니다.

설명하기가 좀 어렵군요. 그래서 코드의 모양과 결과적으로 제가 원하는 것에 대한 예를 보여드리겠습니다. 샘플에서 저는 resultAnalysisFileSql 클래스가 아닌 intype을 사용합니다.

first_list = [1, 12, 12, 5]

second_list = [12, 5, 7, 9, 1]

두 목록을 결합한 결과는 다음과 같습니다. result_list = [1, 12, 5, 7, 9]

결과에는 두 개의 "12" 값이 포함된 첫 번째 목록이 있고, second_list에는 추가로 12, 1 및 5 값이 있습니다.

결과 분석 파일Sql 클래스

[Serializable]
    public partial class ResultAnalysisFileSql
    {
        public string FileSql { get; set; }

        public string PathFileSql { get; set; }

        public List<ErrorAnalysisSql> Errors { get; set; }

        public List<WarningAnalysisSql> Warnings{ get; set; }

        public ResultAnalysisFileSql()
        {

        }

        public ResultAnalysisFileSql(string fileSql)
        {
            if (string.IsNullOrEmpty(fileSql)
                || fileSql.Trim().Length == 0)
            {
                throw new ArgumentNullException("fileSql", "fileSql is null");
            }

            if (!fileSql.EndsWith(Utility.ExtensionFicherosErrorYWarning))
            {
                throw new ArgumentOutOfRangeException("fileSql", "Ruta de fichero Sql no tiene extensión " + Utility.ExtensionFicherosErrorYWarning);
            }

            PathFileSql = fileSql;
            FileSql = ObtenerNombreFicheroSql(fileSql);
            Errors = new List<ErrorAnalysisSql>();
            Warnings= new List<WarningAnalysisSql>();
        }

        private string ObtenerNombreFicheroSql(string fileSql)
        {
            var f = Path.GetFileName(fileSql);
            return f.Substring(0, f.IndexOf(Utility.ExtensionFicherosErrorYWarning));
        }


        public override bool Equals(object obj)
        {
            if (obj == null)
                return false;
            if (!(obj is ResultAnalysisFileSql))
                return false;

            var t = obj as ResultAnalysisFileSql;
            return t.FileSql== this.FileSql
                && t.PathFileSql == this.PathFileSql
                && t.Errors.Count == this.Errors.Count
                && t.Warnings.Count == this.Warnings.Count;
        }


    }

중복을 결합하고 제거하기 위한 샘플 코드가 있습니까?

Enumerable을 살펴보셨습니까?유니온

이 메서드는 반환 집합에서 중복 항목을 제외합니다.이는 중복 항목을 포함하여 입력 시퀀스의 모든 요소를 반환하는 Concat 메서드와는 다른 동작입니다.

List<int> list1 = new List<int> { 1, 12, 12, 5};
List<int> list2 = new List<int> { 12, 5, 7, 9, 1 };
List<int> ulist = list1.Union(list2).ToList();

// ulist output : 1, 12, 5, 7, 9

왜 단순히 그렇지 않습니까?

var newList = list1.Union(list2)/*.Distinct()*//*.ToList()*/;

오... 문서에 따르면 당신은 생략할 수 있습니다..Distinct()

이 메서드는 반환 세트에서 중복 항목을 제외합니다.

유니언의 성능이 좋지 않습니다. 이 기사에서는 이들을 함께 비교하는 방법을 설명합니다.

var dict = list2.ToDictionary(p => p.Number);
foreach (var person in list1)
{
        dict[person.Number] = person;
}
var merged = dict.Values.ToList();

목록 및 LINQ 병합: 4820ms
사전 병합: 16ms
해시 집합 및 IE 품질 비교기: 20ms
LINQ Union과 IE 품질 비교: 24ms

Linq's Union 사용:

using System.Linq;
var l1 = new List<int>() { 1,2,3,4,5 };
var l2 = new List<int>() { 3,5,6,7,8 };
var l3 = l1.Union(l2).ToList();
    List<int> first_list = new List<int>() {
        1,
        12,
        12,
        5
    };

    List<int> second_list = new List<int>() {
        12,
        5,
        7,
        9,
        1
    };

    var result = first_list.Union(second_list);

언급URL : https://stackoverflow.com/questions/4031262/how-to-merge-2-listt-and-removing-duplicate-values-from-it-in-c-sharp

반응형