Python字典列表投影、过滤器或子集



我正试图创建一个我认为是从较大字典空间到较小维度空间的"投影"。所以,如果我有:

mine = [
{"name": "Al", "age": 10},
{"name": "Bert", "age": 15},
{"name": "Charles", "age": 17}
]

我正试图找到一个只返回的函数表达式:

[
{"name": "Al"},
{"name": "Bert"},
{"name": "Charles"}
]

我试过了。。。

>>> filter(lambda x: x['name'],mine)
[{'age': 10, 'name': 'Al'}, {'age': 15, 'name': 'Bert'}, {'age': 17, 'name': 'Charles'}]
>>> map(lambda x : x['name'],mine)
['Al', 'Bert', 'Charles']

但似乎仍然缺少正确的功能。我知道如何进行列表理解,但我想学习如何在功能上做到这一点。

无论你喜欢与否,这听起来都像是一项列表理解的工作。

>>> [{"name": d["name"]} for d in mine]
[{'name': 'Al'}, {'name': 'Bert'}, {'name': 'Charles'}]

没有列表理解的解决方案将需要额外的功能定义:

def project(key, d):
    return {k: d[k]}
map(partial(project, "name"), mine)

或者lambda(是的):

map(lambda d: {"name": d["name"]}, mine)

代码:

print([{'name': d['name']} for d in mine])

输出:

[{'name': 'Al'}, {'name': 'Bert'}, {'name': 'Charles'}]

如果我们想保留多个密钥:

input_dicts = [
    {"name": "Al", "age": 40, "level": "junior"},
    {"name": "Bert", "age": 30, "level": "mid"},
    {"name": "Charles", "age": 20, "level": "senior"}
]
selected_keys = ("name", "level")
[
    {key: value for key, value in a_dict.items() if key in selected_keys}
    for a_dict in input_dicts
]
[{'name': 'Al', 'level': 'junior'},
 {'name': 'Bert', 'level': 'mid'},
 {'name': 'Charles', 'level': 'senior'}]

相关内容

  • 没有找到相关文章

最新更新