Musiałem usunąć niektóre pola ze słownika, klucze tych pól znajdują się na liście. Więc piszę tę funkcję:Elegancki sposób usuwania pól ze słowników zagnieżdżonych
def delete_keys_from_dict(dict_del, lst_keys):
"""
Delete the keys present in the lst_keys from the dictionary.
Loops recursively over nested dictionaries.
"""
dict_foo = dict_del.copy()#Used as iterator to avoid the 'DictionaryHasChanged' error
for field in dict_foo.keys():
if field in lst_keys:
del dict_del[field]
if type(dict_foo[field]) == dict:
delete_keys_from_dict(dict_del[field], lst_keys)
return dict_del
Ten kod działa, ale nie jest zbyt elegancki i jestem pewien, że możesz napisać lepsze rozwiązanie.
hmmm znajdę to elegancki! –
Myślę, że to nie jest zły kod; masz ważny bit, który jest rekursywny w przypadku zagnieżdżonych słowników. Powinieneś prawdopodobnie sprawdzić, czy 'isinstance (spam, collections.MutableMapping)' jest bardziej polimorficzny. – katrielalex