Как я могу сравнить два списка с определенным ключом в dict в python

#python

#python

Вопрос:

Я хочу взять два списка со значением dict и найти конкретные значения, которые отображаются только в первом списке.

В этом случае сравнивайте только ключ ‘name’.

 a = [
       {'name': 'joseph', 'age': 33}, 
       {'name': 'Emma', 'age': 11}, 
       {'name': 'apple', 'age': 44}
    ]
b = [ 
       {'name': 'apple', 'age': 44}, 
       {'name': 'Emma', 'age': 22}
    ]
  

returnOnlyOne(a, b)
вернул бы [{'name': 'joseph', 'age': 33}] , например.

set() Решение не для этого случая.

Ответ №1:

Для повышения эффективности мы сначала создаем set список имен в 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 и тому подобное, вы можете написать то же самое, используя comprehensions:

 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]
  

Ответ №2:

Используйте 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 : проверяет, не существует ли в имени a из b . (т. е. отображается только в первом списке)

Ответ №3:

Почти такой же, как у других.

 print([ item for item in a if item['name'] not in set(item['name'] for item in b)])