J'ai deux listes Liste que je dois combiner et en supprimant les valeurs en double des deux listes
C'est un peu difficile à expliquer, alors laissez-moi vous montrer un exemple de ce à quoi le code ressemble, et ce que je veux en conséquence, dans l'échantillon, j'utilise le type int, pas la classe ResultAnalysisFileSql.
first_list = [1, 12, 12, 5]
second_list = [12, 5, 7, 9, 1]
Le résultat de la combinaison des deux listes devrait donner la liste suivante: result_list = [1, 12, 5, 7, 9]
Vous remarquerez que le résultat a la première liste, y compris ses deux valeurs "12", et dans second_list, une valeur supplémentaire de 12, 1 et 5.
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;
}
}
Un exemple de code pour combiner et supprimer les doublons?
Avez-vous jeté un coup d'œil à Enumerable.Union
Cette méthode exclut les doublons de l'ensemble de retour . Ce comportement diffère de celui de la méthode Concat, qui renvoie tous les éléments des séquences d'entrée, y compris les doublons.
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();
pourquoi pas simplement par exemple
var newList = list1.Union(list2)/*.Distinct()*//*.ToList()*/;
oh ... selon msdn vous pouvez laisser de côté la .Distinct()
Cette méthode exclut les doublons du jeu de retour
L’Union n’a pas de bonnes performances: ceci article décrire à propos de les comparer avec
var dict = list2.ToDictionary(p => p.Number);
foreach (var person in list1)
{
dict[person.Number] = person;
}
var merged = dict.Values.ToList();
Fusion des listes et LINQ: 4820ms
Fusion du dictionnaire: 16ms
HashSet et IEqualityComparer: 20ms
LINQ Union et IEqualityComparer: 24 ms
Utilisez l'union de 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();
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);