【发布时间】:2010-07-26 19:15:31
【问题描述】:
我正在尝试从可枚举中构建字典,但我需要一个聚合器来存储所有可能重复的键。直接使用 ToDictionary() 有时会导致重复键。
在这种情况下,我有一堆时间条目({ DateTime Date, double Hours }),如果同一天出现多个时间条目,我想要当天的总时间。即,一个自定义聚合器,它将为我提供一个字典条目的唯一键。
还有比这更好的方法吗?
(这确实有效。)
private static Dictionary<DateTime, double> CreateAggregatedDictionaryByDate( IEnumerable<TimeEntry> timeEntries )
{
return
timeEntries
.GroupBy(te => new {te.Date})
.Select(group => new {group.Key.Date, Hours = group.Select(te => te.Hours).Sum()})
.ToDictionary(te => te.Date, te => te.Hours);
}
我想我真的在寻找这样的东西:
IEnumerable<T>.ToDictionary(
/* key selector : T -> TKey */,
/* value selector : T -> TValue */,
/* duplicate resolver : IEnumerable<TValue> -> TValue */ );
所以...
timeEntries.ToDictionary(
te => te.Date,
te => te.Hours,
duplicates => duplicates.Sum() );
“解析器”可以是 .First() 或 .Max() 或其他。
或类似的东西。
我有一个实现......当我正在研究它时,另一个出现在答案中。
我的:
public static Dictionary<TKey, TValue> ToDictionary<T, TKey, TValue>(
this IEnumerable<T> input,
Func<T, TKey> keySelector,
Func<T, TValue> valueSelector,
Func<IEnumerable<TValue>, TValue> duplicateResolver)
{
return input
.GroupBy(keySelector)
.Select(group => new { group.Key, Value = duplicateResolver(group.Select(valueSelector)) })
.ToDictionary(k => k.Key, k => k.Value);
}
我希望已经有类似的东西了,但我想没有。这将是一个很好的补充。
谢谢大家:-)
【问题讨论】:
-
您的意思是要使密钥唯一化,还是要删除 dups?
-
我更新了描述。尝试聚合重复项以使其唯一,然后从中构建字典。
标签: c# linq dictionary group-by aggregate