non ho potuto ottenere la soluzione di NaveenBhat a lavorare, ottenendo un errore di compilazione:
The type arguments for method 'System.Linq.Enumerable.GroupBy(System.Collections.Generic.IEnumerable, System.Func, System.Collections.Generic.IEqualityComparer)' cannot be inferred from the usage. Try specifying the type arguments explicitly.
per farlo funzionare, l'ho trovato più semplice e più chiaro per definire una nuova classe dove riporre i miei colonne chiave (GroupKey) , quindi una classe separata che implementa IEqualityComparer (KeyComparer). Posso quindi chiamare
var result= source.GroupBy(r => new GroupKey(r), new KeyComparer());
classe Il KeyComparer non confrontare le corde con l'operatore di confronto InvariantCultureIgnoreCase, quindi complimenti a NaveenBhat per avermi nella giusta direzione.
versioni semplificate dei miei corsi:
private class GroupKey
{
public string Column1{ get; set; }
public string Column2{ get; set; }
public GroupKey(SourceObject r) {
this.Column1 = r.Column1;
this.Column2 = r.Column2;
}
}
private class KeyComparer: IEqualityComparer<GroupKey>
{
bool IEqualityComparer<GroupKey>.Equals(GroupKey x, GroupKey y)
{
if (!x.Column1.Equals(y.Column1,StringComparer.InvariantCultureIgnoreCase) return false;
if (!x.Column2.Equals(y.Column2,StringComparer.InvariantCultureIgnoreCase) return false;
return true;
//my actual code is more complex than this, more columns to compare
//and handles null strings, but you get the idea.
}
int IEqualityComparer<GroupKey>.GetHashCode(GroupKey obj)
{
return 0.GetHashCode() ; // forces calling Equals
//Note, it would be more efficient to do something like
//string hcode = Column1.ToLower() + Column2.ToLower();
//return hcode.GetHashCode();
//but my object is more complex than this simplified example
}
}
fonte
2014-09-05 22:19:23
Questo non funziona? 'a => {Column1 = a.Column1.ToLower(), Column2 = a.Column2.ToLower()}' –