【发布时间】:2011-05-01 04:24:04
【问题描述】:
我有两个列表列表,我需要将它们合并到第三个列表中并从列表中删除重复值
有点难以解释,所以让我举一个例子来说明代码的样子和我想要的结果,在示例中我使用 int 类型而不是 ResultAnalysisFileSql 类。
first_list = [1, 12, 12, 5]
second_list = [12, 5, 7, 9, 1]
合并两个列表的结果应该是这个列表: 结果列表 = [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;
}
}
任何用于合并和删除重复项的示例代码?
【问题讨论】:
标签: c# list merge duplicates