@ Marcin odpowiada wszystkim, ale na wypadek gdyby ktoś chciał zobaczyć rzeczywisty przykład, poniżej dodaję dwa:
Powiedzmy, że masz następujący słownik zestawów
d = {'key1': {'a', 'b', 'c'}, 'key2': {'foo', 'bar'}, 'key3': {'so', 'sad'}}
i chcesz utworzyć nowy słownik, którego klucze wskazują, czy ciąg 'a'
jest zawarty w wartościach, czy nie, możesz użyć
dout = {"a_in_values_of_{}".format(k) if 'a' in v else "a_not_in_values_of_{}".format(k): v for k, v in d.items()}
która daje
{'a_in_values_of_key1': {'a', 'b', 'c'},
'a_not_in_values_of_key2': {'bar', 'foo'},
'a_not_in_values_of_key3': {'sad', 'so'}}
Teraz załóżmy, że masz dwa takie słowniki
d1 = {'bad_key1': {'a', 'b', 'c'}, 'bad_key2': {'foo', 'bar'}, 'bad_key3': {'so', 'sad'}}
d2 = {'good_key1': {'foo', 'bar', 'xyz'}, 'good_key2': {'a', 'b', 'c'}}
i chcesz zastąpić klucze w d1
kluczami lub d2
jeśli odpowiednie wartości są identyczne, możesz to zrobić
dout2 = {d2.keys()[d2.values().index(v1)] if v1 in d2.values() else k1: v1 for k1, v1 in d1.items()}
dout2 = {list(d2.keys())[list(d2.values()).index(v1)] if v1 in d2.values() else k1: v1 for k1, v1 in d1.items()}
co daje
{'bad_key2': {'bar', 'foo'},
'bad_key3': {'sad', 'so'},
'good_key2': {'a', 'b', 'c'}}
dict
składa się zkey:value
elementów, nie budujeszdict
tutaj, ale aset
(patrz zestaw literałów ).