Oto bardzo ogólna odpowiedź przeznaczona do obsługi wielokrotnych wystąpień wielu wartości w dużych słownikach. Obsługa prostszych, bardziej szczegółowych przypadków i/lub małych słowników - jak na przykład - może być wykonana znacznie szybciej.
from collections import defaultdict
my_dicts = [
{ 'key1' : 'value1',
'key2' : 'value2' },
{ 'key1' : 'value1',
'key2' : 'value2',
'key3' : 'value2' }, # dup added for testing
{ 'key1' : 'value1',
'key2' : 'value2' }]
def reverse(dct):
""" Create dictionary mapping each value to list of one or more keys """
ret = defaultdict(list)
for key,val in dct.iteritems():
ret[val].append(key)
return ret
def replace_values(dicts, replacments):
""" Replace values in each dict in dicts """
for dct in dicts:
revdict = reverse(dct)
for oldval,newval in replacments.iteritems():
for key in revdict.get(oldval, []):
dct[key] = newval
replace_values(my_dicts, {'value2':'value3'})
print my_dicts
# [{'key2': 'value3', 'key1': 'value1'},
# {'key3': 'value3', 'key2': 'value3', 'key1': 'value1'},
# {'key2': 'value3', 'key1': 'value1'}]
Szukasz "wartości 2" w ramach różnych "kluczy X"? Ile aktualizacji będziesz wykonywał, po jednym na każde przejście? – kevpie
Jakie założenia można sformułować - na przykład czy będzie zawsze kojarzony z tym samym kluczem, czy może występować pod innymi lub wieloma kluczami? Czy kiedykolwiek chcesz aktualizować więcej niż jedną wartość naraz? – martineau