LINQ查询以返回Dictionary <string,string>


218

我有一个MyClass集合,我想使用LINQ查询以获取不同的值,并返回一个Dictionary <string,string>作为结果,但是我不知道该如何做比我更简单的事情在做下面。我可以用来获取Dictionary <string,string>作为结果的更简洁的代码是什么?

var desiredResults = new Dictionary<string, string>(StringComparer.OrdinalIgnoreCase);

var queryResults = (from MyClass mc in myClassCollection
                    orderby bp.SomePropToSortOn
                    select new KeyValuePair<string, string>(mc.KeyProp, mc.ValueProp)).Distinct();

foreach (var item in queryResults)
{
    desiredResults.Add(item.Key.ToString(), item.Value.ToString());
}

6
您希望它与重复的密钥一起做什么?只是选择第一个而忽略后续的?请注意,没有对字典进行排序,因此您在查询中的排序将无效……
Jon Skeet

1
也许您正在寻找的是IDictionary的SortedDictionary实现。否则,对字典进行排序是没有意义的。
Fede 2010年

Answers:


366

ToDictionary直接使用该方法。

var result = 
  // as Jon Skeet pointed out, OrderBy is useless here, I just leave it 
  // show how to use OrderBy in a LINQ query
  myClassCollection.OrderBy(mc => mc.SomePropToSortOn)
                   .ToDictionary(mc => mc.KeyProp.ToString(), 
                                 mc => mc.ValueProp.ToString(), 
                                 StringComparer.OrdinalIgnoreCase);

1
Mehrdad,谢谢您的指导。这就是我要走的方向,但是一定是因为忽略了ToDictionary的正确重载。
Scott Ivey

18

查看ToLookup和/或ToDictionary扩展方法。

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.