Kiq*_*net 142 c# merge list duplicates
我有两个列表列表,我需要组合并删除两个列表的重复值
有点难以解释,所以让我展示代码的样子,以及我想要的结果,在示例中我使用int类型而不是ResultAnalysisFileSql类.
first_list = [1,12,12,5]
second_list = [12,5,7,9,1]
组合这两个列表的结果应该产生这个列表:resul_list = [1,12,5,7,9]
你会注意到结果有第一个列表,包括它的两个"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;
        }
    }
Run Code Online (Sandbox Code Playgroud)
用于组合和删除重复项的任何示例代码?
Adr*_*der 263
你看过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();
Run Code Online (Sandbox Code Playgroud)
        And*_*air 29
为什么不简单,例如
var newList = list1.Union(list2)/*.Distinct()*//*.ToList()*/;
Run Code Online (Sandbox Code Playgroud)
哦...根据msdn,你可以省略.Distinct()
此方法从返回集中排除重复项
小智 22
联盟没有良好的表现:本文描述了将它们一起比较
var dict = list2.ToDictionary(p => p.Number);
foreach (var person in list1)
{
        dict[person.Number] = person;
}
var merged = dict.Values.ToList();
Run Code Online (Sandbox Code Playgroud)
列表和LINQ合并:4820ms 
字典合并:16ms 
HashSet和IEqualityComparer:20ms 
LINQ Union和IEqualityComparer:24ms  
Rob*_*sen 13
使用Linq的联盟:
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();
Run Code Online (Sandbox Code Playgroud)
        Fai*_* S. 10
    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);
Run Code Online (Sandbox Code Playgroud)