我有一些看起来像这样的代码:
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')
有比上述更好的解决方案吗?
答案 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}