LINQ 查询返回 Dictionary<string, string>
Posted
技术标签:
【中文标题】LINQ 查询返回 Dictionary<string, string>【英文标题】:LINQ query to return a Dictionary<string, string> 【发布时间】:2009-03-09 20:21:29 【问题描述】:我有一个 MyClass 的集合,我想使用 LINQ 进行查询以获取不同的值,并返回 Dictionary
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());
【问题讨论】:
你希望它对重复键做什么?只取第一个而忽略后面的?请注意,字典没有排序,因此您在查询中的排序将无效... 也许您正在寻找的是 IDictionary 的 SortedDictionary 实现。否则对字典的排序是没有意义的。 【参考方案1】:直接使用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);
【讨论】:
Mehrdad,感谢您的指点。这是我要走的方向,但 for 一定是忽略了 ToDictionary 的正确重载。【参考方案2】:查看ToLookup
和/或ToDictionary
扩展方法。
【讨论】:
以上是关于LINQ 查询返回 Dictionary<string, string>的主要内容,如果未能解决你的问题,请参考以下文章
DataReader 到 Linq'd 查询 Dictionary(String, Object)
无法将类型为“Newtonsoft.Json.Linq.JObject”的对象转换为类型“System.Collections.Generic.Dictionary`2[System.String,S
Linq 到 Dictionary<string, string[]>。选择值包含条件字符串的键
ASP.NET 中 把返回的List<Dictionary<string, object>>的第一条记录的某个值绑定到Button中