我有两个列表列表,我需要在第三个列表中合并并从该列表中删除重复值
有点难以解释,所以让我展示一个示例,说明代码的外观以及我想要的结果,在示例中我使用 int 类型而不是 ResultAnalysisFileSql 类。
first_list = [1, 12, 12, 5]
second_list = [12, 5, 7, 9, 1]
组合两个列表的结果应该是这个列表:resulting_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(); // ulist output : 1, 12, 5, 7, 9