1. ホーム
  2. c#

[解決済み] C#で2つのList<T>をマージし、重複する値を削除する方法

2022-04-20 05:58:28

質問

2つのリストがあり、それを3番目のリストに結合し、そのリストから重複する値を削除する必要があります。

ちょっと説明が難しいので、どのようなコードで、どのような結果が欲しいのかの例を示します。サンプルでは、ResultAnalysisFileSqlクラスではなく、int型を使っています。

first_list = [1, 12, 12, 5] とする。

second_list = [12, 5, 7, 9, 1] です。

2つのリストを組み合わせた結果は、このようなリストになるはずです。 resulting_list = [1, 12, 5, 7, 9] となります。

結果には、最初のリストとその2つの値quot;12"があり、second_listにはさらに12、1、5の値があることに気がつくでしょう。

ResultAnalysisFileSqlクラス

[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.Union(エンミュラブル・ユニオン

このメソッドは、返されるセットから重複を除外します。 . これは違う ビヘイビアを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