C#Linq合并了两个词典

时间:2012-04-05 19:33:34

标签: c# linq merge functional-programming

如何使以下方法更具功能性?linq-style?

    public static Dictionary<T, T> MergeDict<T, T>(Dictionary<T, T> a, Dictionary<T, T> b)
    {
        var e = new Dictionary<T, T>();

        a.Concat(b).ToList().ForEach(pair =>
        {
            e[pair.Key] = pair.Value;
        });

        return e;
    }

3 个答案:

答案 0 :(得分:10)

要继续使用重复的丢弃方式,只需分组并获取组中的获胜项目(例如最后一项)。

first.Concat(second)
  .GroupBy(kvp => kvp.Key, kvp => kvp.Value)
  .ToDictionary(g => g.Key, g => g.Last());

答案 1 :(得分:3)

您可以直接使用ToDictionary

public static Dictionary<T, T> MergeDict<T, T>(Dictionary<T, T> a, Dictionary<T, T> b)
{
     return a.Concat(b).ToDictionary(kvp => kvp.Key, kvp => kvp.Value);
}

请注意,这会在重复键的情况下引发异常。

如果您需要处理重复的密钥,您需要决定如何处理这些密钥。例如,这将删除“b”中的重复项:

public static Dictionary<T, T> MergeDict<T, T>(Dictionary<T, T> a, Dictionary<T, T> b)
{
     return a.Concat(b.Where(kvp => !a.ContainsKey(kvp.Key)).ToDictionary(kvp => kvp.Key, kvp => kvp.Value);
}

要获得与原始行为相同的行为,您可以采用另一种方式(将KeyValuePair值保持为“b”):

public static Dictionary<T, T> MergeDict<T, T>(Dictionary<T, T> a, Dictionary<T, T> b)
{
     return b.Concat(a.Where(kvp => !b.ContainsKey(kvp.Key)).ToDictionary(kvp => kvp.Key, kvp => kvp.Value);
}

答案 2 :(得分:0)

也许就是这样。

public static IDictionary<T, U> Merge<T, U>(this IDictionary<T, U> first, IDictionary<T, U> second)
{
    return first.Concat(second).ToDictionary(kvp => kvp.Key, kvp => kvp.Value);
}