首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > .NET > .NET >

Linq除了List的重复行

2014-07-10 来源:读书人网 【读书人网(Reader8.cn):综合教育门户网站】
Linq去除List的重复行Dc为多个string的集合,里面有Name,IssuerCode,LACode;List中想去掉多个IssuerCod

Linq去除List的重复行
Dc为多个string的集合,里面有Name,IssuerCode,LACode;
List<Dc>中想去掉多个IssuerCode和LACode重复的
比如:List<DC>里面有 peter,I001,LA001,LAcc
                     jenny,I001,LA001,LAcc
                     macus,I002,LA002,LAdd
                      joan,I002,LA002,LAdd
                      tina,I003,LA003,LAee
                      luna,I003,LA003,LAee
                      lucy,I003,LA003,LAee
想得到最后的结果是:peter,I001,LA001,LAcc
                    macus,I002,LA002,LAdd
                     tina,I003,LA003,LAee

List.Distinct又不行。菜鸟在此请教各位大侠,这个List该如何去除其中某几个重复项?
[解决办法]
lst.Distinct<DC>();

DC类集成IComparable,IComparer接口,实现比较函数就可以用Distinct<DC>()了
[解决办法]
list=list.GroupBy(t=>t.issuercode).Select(t=>t.First()).ToList();
[解决办法]
见myblog:

http://blog.csdn.net/q107770540/article/details/5784646
[解决办法]

 list=list.Distinct(new DcComparer ()).ToList();

    public class DcComparer : IEqualityComparer<Dc>
    {
        public bool Equals(Dc t1, Dc t2)
        {
            return (t1.IssuerCode== t2.IssuerCode&& t1.LACode== t2.LACode);
        }
        public int GetHashCode(Dc t)
        {
            return t.ToString().GetHashCode();
        }
    }

[解决办法]
引用:
list=list.GroupBy(t=>t.issuercode).Select(t=>t.First()).ToList();


这个最简单
var query = list.GroupBy(x => new { /*在这里放入你视为重复的列,用逗号分割,比如*/ x.IssuerCode, x.LACode }).Select(x => x.First()).ToList();
[解决办法]
参考Distinct和SequenceEqual