我有两个列表,我需要将它们合并到第三个列表中,并从该列表中删除重复的值
有点难以解释,所以让我展示一个示例代码看起来和结果想要的例子,在示例中我使用int类型而不是ResultAnalysisFileSql类。
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值。
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();