检索出 IList<T> 或 List<T>中的不重复数据 Distinct()
来源:互联网 发布:淘宝开店怎么关闭店铺 编辑:程序博客网 时间:2024/06/05 21:12
http://www.soaspx.com/dotnet/csharp/csharp_20130513_10318.html
Distinct()方法在MSDN中的示例
public class Product{ public string Name { get; set; } public int Code { get; set; }}
Product[] products = { new Product { Name = "apple", Code = 9 }, new Product { Name = "orange", Code = 4 }, new Product { Name = "apple", Code = 10 }, new Product { Name = "lemon", Code = 9 } };var lstDistProduct = products.Distinct();foreach (Product p in list1){ Console.WriteLine(p.Code + " : " + p.Name);}
但在实际使用中发现往往无法实现筛选出不重复的数据的目的
查找相关资料获得如下方法:
方法1:使用MoreLinq库
var list1 = products.DistinctBy(x=> x.Code);foreach (Product p in list1){ Console.WriteLine(p.Code + " : " + p.Name);}
方法2:
class ProductComparare : IEqualityComparer<product> { private Func<Product, object> _funcDistinct; public ProductComparare(Func<Product, object> funcDistinct) { this._funcDistinct = funcDistinct; } public bool Equals(Product x, Product y) { return _funcDistinct(x).Equals(_funcDistinct(y)); } public int GetHashCode(Product obj) { return this._funcDistinct(obj).GetHashCode(); } }
var list2 = products.Distinct(new ProductComparare( a => a.Code )); foreach (Product p in list2) { Console.WriteLine(p.Code + " : " + p.Name); }
方法3:
List<Product> list = products .GroupBy(a => a.Code ) .Select(g => g.First()) .ToList(); foreach (Product p in list) { Console.WriteLine(p.Code + " : " + p.Name); }
本人通过第三种方法得到了想要的不重复数据。
0 0
- 检索出 IList<T> 或 List<T>中的不重复数据 Distinct()
- Linq List<T>.Distinct() 去除对象重复
- List<T>与IList<T>的区别
- Ilist<T>转换为List<T>
- IList<T>和List<T>区别
- List<T>和Ilist<T>的区别
- Java list<T> 去重复 数据
- C#中List<T> 和 IList<T> 的比较
- C#中IList<T>与List<T>的区别
- C#中IList<T>与List<T>的区别感想
- C#编程之IList<T>、List<T>和ArrayList
- 过滤ilist中的重复数据
- IList,IList<T>转成dataSet
- FCL应用技巧之------使用List<T>的Distinct()去除重复元素
- 集合 List<T> 排重方法 Distinct()
- C# List<T>之distinct用法
- IList(T)转换DataSet
- IList(T) 方法
- AFNetworking 初探
- mysql 5.5 设置编码问题
- Web性能测试基本性能指标及案例分析
- sp_depends 被检查相关性的数据库对象。对象可以是表、视图、存储过程或触发器 in sql server
- myeclipse设置字体大小
- 检索出 IList<T> 或 List<T>中的不重复数据 Distinct()
- IOS操作SQLite
- WebService之Axis2系列教程(一)Axis2的下载、安装和使用
- 让我们彻底搞懂C/C++函数指针吧(一)
- 开源中国iOS客户端学习——(八)网络通信AFNetworking类库
- oracle中plsql developer工具的commandwindow 和 sqlwindow有什么区别啊
- AndroidUI效果--开源项目IndexableListView(字母索引)
- jsp页面errorPage设定,没有跳转,出现500错误
- 2、数据转换String相关