ToDictionary()LINQ扩展方法

ToList() 使用IEnumerable<T>并将其转换为 List<T>,那么 ToDictionary()也是类似的。大多数情况ToDictionary()是一个非常方便的方法,将查询的结果(或任何 IEnumerable<T>)转换成一个Dictionary<TKey,TValue>。 关键是您需要定义T如何分别转换TKey和TValue。

如果说我们有超级大的产品列表,希望把它放在一个Dictionary<int, product>,这样我们可以根据ID得到最快的查找时间。 你可能会这样做:

  var results = new Dictionary<int, Product>();
  foreach (var product in products)
  {
      results.Add(product.Id, product);
  }

和它看起来像一个很好的代码,但是我们可以轻松地使用LINQ而无需手写一大堆逻辑:

 var results = products.ToDictionary(product =>  product.Id);

它构造一个Dictionary<int, Product> ,Key是产品的Id属性,Value是产品本身。 这是最简单的形式ToDictionary(),你只需要指定一个key选择器。 如果你想要不同的东西作为你的value? 例如如果你不在乎整个Product,,你只是希望能够转换ID到Name? 我们可以这样做:

 var results = products.ToDictionary(product =>  product.Id, product =>  product.Name);

这将创建一个 Key为Id,Value为Name 的Dictionary<int, string>,。由此来看这个扩展方法有很多的方式来处理IEnumerable<T> 集合或查询结果来生成一个dictionary。

 注:还有一个Lookup<TKey, TValue>类和ToLookup()扩展方法,可以以类似的方式做到这一点。 他们不是完全相同的解决方案(Dictionary和Lookup接口不同,他们的没有找到索引时行为也是不同的)。

因此,在我们的Product 示例中,假设我们想创建一个Dictionary<string, List<Product>> ,Key是分类,Value是所有产品的列表。 在以前你可能自实现自己的循环:

 

 1 // create your dictionary to hold results
 2  var results = new Dictionary<string, List<Product>>();
 3   
 4 // iterate through products
 5  foreach (var product in products)
 6 {
 7     List<Product> subList;
 8  
 9     // if the category is not in there, create new list and add to dictionary
10      if (!results.TryGetValue(product.Category, out subList))
11     {
12          subList = new List<Product>();
13          results.Add(product.Category, subList);
14     }
15   
16      // add the product to the new (or existing) sub-list
17      subList.Add(product);
18  }

但代码应该更简单! 任何新人看着这段代码可能需要去详细分析才能完全理解它,这给维护带来了困难

幸运的是,对我们来说,我们可以利用LINQ扩展方法GroupBy()提前助力ToDictionary()和ToList():

 // one line of code!

 var results = products.GroupBy(product =>  product.Category)

.ToDictionary(group =>  group.Key, group =>  group.ToList());

GroupBy()是用Key和IEnumerable创建一个IGrouping的LINQ表达式查询语句。 所以一旦我们使用GroupBy() ,所有我们要做的就是把这些groups转换成dictionary,所以我们的key选择器 (group => group.Key) 分组字段(Category),使它的成为dictionary的key和Value择器((group =>  group.ToList()) 项目,并将它转换成一个List<Product>作为我们dictionary的Value!

这样更容易读和写,单元测试的代码也更少了! 我知道很多人会说lamda表达式更难以阅读,但他们是c#语言的一部分,高级开发人员也必须理解。我认为你会发现当你越来越多的使用他们后,代码能被更好的理解和比以前更具可读性。

















转载于:https://www.cnblogs.com/apollo-blog/p/7419495.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
LINQ(Language Integrated Query)是.NET Framework的一种语言集成查询,它允许我们在C#或VB.NET代码中使用SQL类似的语法来查询数据。LINQ扩展方法是一种在LINQ查询中使用的方法,它们可以用于对数据进行排序、筛选、分组和投影等操作,以及执行聚合函数。 下面是几个LINQ扩展方法的应用实例: 1. Where方法:筛选符合条件的元素 ```csharp List<int> numbers = new List<int> { 1, 2, 3, 4, 5, 6 }; IEnumerable<int> result = numbers.Where(n => n % 2 == 0); ``` 2. OrderBy方法:按照指定的方式排序 ```csharp List<int> numbers = new List<int> { 6, 2, 4, 1, 5, 3 }; IEnumerable<int> result = numbers.OrderBy(n => n); ``` 3. GroupBy方法:按照指定的字段进行分组 ```csharp List<Person> people = new List<Person> { new Person { Name = "Alice", Age = 25 }, new Person { Name = "Bob", Age = 30 }, new Person { Name = "Charlie", Age = 25 }, new Person { Name = "Dave", Age = 30 } }; IEnumerable<IGrouping<int, Person>> result = people.GroupBy(p => p.Age); ``` 4. Select方法:对查询结果进行投影 ```csharp List<Person> people = new List<Person> { new Person { Name = "Alice", Age = 25 }, new Person { Name = "Bob", Age = 30 }, new Person { Name = "Charlie", Age = 25 }, new Person { Name = "Dave", Age = 30 } }; IEnumerable<string> result = people.Select(p => p.Name); ``` 这些方法只是LINQ扩展方法中的一部分,它们的应用可以大大简化我们对数据的处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值