创建一个包含来自另一个字典的特定键值对的Python字典

时间:2012-02-18 11:48:31

标签: python dictionary

我有一些看起来像这样的代码:

d = {'foo': True, 'bar': 42, 'baz': '!'}

a = {'foo': d['foo'], 'bar': d['bar']}
b = {'foo': d['foo'], 'baz': d['baz']}
c = {'bar': d['bar'], 'baz': d['baz']}

肯定有更好的方式来表达这一点。我实际上阅读了文档,希望字典的copy方法接受键包含在新词典中:

# I'd hoped that something like this would work...
a = d.copy('foo', 'bar')
b = d.copy('foo', 'baz')
c = d.copy('bar', 'baz')

我可以为此目的编写一个函数:

copydict = lambda dct, *keys: {key: dct[key] for key in keys}

a = copydict(d, 'foo', 'bar')
b = copydict(d, 'foo', 'baz')
c = copydict(d, 'bar', 'baz')

有比上述更好的解决方案吗?

3 个答案:

答案 0 :(得分:6)

我想问题中的函数是最好的解决方案。

当然,有人可以发布一些惯用的代码,但我相信它不会更好/更快。迭代列表并按键从字典中获取项目的速度尽可能快。

一个建议是从keys参数中删除星号。参数解包会增加不必要的开销。将这些键作为元组传递应该没有问题。

答案 1 :(得分:3)

我要做的唯一改进是使用真正的函数定义,而不是lambda:

def copy_dict(d, *keys):
    """Make a copy of only the `keys` from dictionary `d`."""
    return {key: d[key] for key in keys}

处理丢失的键可能很有用,但在Python 2中,你不能很好地将可选的关键字参数与* args混合,所以你可能需要转到元组参数:

def copy_dict(d, keys, default=None):
    """Make a copy of only the `keys` from dictionary `d`.

    Use `default` if a key is missing.

    """
    return {key: d.get(key, default) for key in keys}

答案 2 :(得分:0)

正如@BlaXpirit所指出的,这个解决方案在速度或可读性方面可能不会比你的更好,但你可以这样做:

>>> from operator import itemgetter
>>> d = {'foo': True, 'bar': 42, 'baz': '!'}
>>> keys = ['foo', 'bar']
>>> dict(zip(keys, itemgetter(*keys)(d)))
{'bar': 42, 'foo': True}