Eu tenho duas listas Lista que preciso combinar na terceira lista e remover valores duplicados dessas listas
Um pouco difícil de explicar, então deixe-me mostrar um exemplo de como o código se parece e o que eu quero como resultado. No exemplo, eu uso o tipo int, não a classe ResultAnalysisFileSql.
first_list = [1, 12, 12, 5]
second_list = [12, 5, 7, 9, 1]
O resultado da combinação das duas listas deve resultar nessa lista: result_list = [1, 12, 5, 7, 9]
Você notará que o resultado possui a primeira lista, incluindo seus dois valores "12", e em second_list os 12, 1 e 5 adicionais.
Classe 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;
}
}
Algum código de amostra para combinar e remover duplicatas?
fonte
cannot be inferred from the usage
erro.porque não simplesmente por exemplo
ah ... de acordo com o msdn você pode deixar de fora o
.Distinct()
fonte
A união não tem bom desempenho: este artigo descreve como compará-los com
Mesclagem de listas e LINQ: 4820ms Mesclagem de
dicionário: 16ms
HashSet e IEqualityComparer: 20ms
LINQ Union e IEqualityComparer: 24ms
fonte
Union
resulta em um código mais limpo e mais legível. Gastar tempo para otimizar o código quando não é lento pode resultar em uma penalidade de manutenção no caminho.Use a união da Linq:
fonte
fonte