3 回答
TA贡献1833条经验 获得超4个赞
为了提高效率,我们首先对set中的名称进行 a b,然后过滤列表a:
from operator import itemgetter
def returnOnlyOne(a, b):
b_names = set(map(itemgetter('name'), b))
only_in_a = list(filter(lambda item: item['name'] not in b_names, a))
return only_in_a
示例输出:
a = [
{'name': 'joseph', 'age': 33},
{'name': 'Emma', 'age': 11},
{'name': 'apple', 'age': 44}
]
b = [
{'name': 'apple', 'age': 44},
{'name': 'Emma', 'age': 22}
]
print(returnOnlyOne(a, b))
# [{'name': 'joseph', 'age': 33}]
如果您不喜欢itemgetter,filter等等,您可以使用推导式编写相同的内容:
def returnOnlyOne(a, b):
b_names = set(item['name'] for item in b)
return [ item for item in a if item['name'] not in b_names]
TA贡献1839条经验 获得超15个赞
使用list
理解与map
. (顺便说一句,你里面的东西list
叫做dict
):
[d for d in a if d.get('name') not in list(map(lambda x:x.get('name'), b))] # [{'age': 33, 'name': 'joseph'}]
解释:
list(map(lambda x:x.get('name'), b))
:得到所有的名字从b
d.get('name') not in
: 检查名称from 中a
是否不存在b
。(即只出现在第一个列表中)
TA贡献1815条经验 获得超10个赞
几乎和其他人一样。
print([ item for item in a if item['name'] not in set(item['name'] for item in b)])
添加回答
举报