aplanando diccionarios anidados: comprimir claves
para aplanar un diccionario anidado, deberá iterar recursivamente a través de cada par y valor de valor, creando nuevas claves mediante Subscore.
Los niveles más profundos del diccionario anidado requieren una recursión adicional usando el mismo proceso.
Una vez que haya completado la recursión, cree un nuevo diccionario de los elementos aplastados.
aquí hay una implementación de la importación de PyThon. Def Flatten (diccionario, parent_key = '', separator = '_'): elementos = [] Para la clave, valor en diccionario.items (): new_key = KEKEPADOR DE PARTE_KEY SI SI LA CLAVE DE PARTE_KEY ELE Si es ISInstance (valor, mutableMapping): items.extend (Flatten (valor, new_key, separator = separator) .Items ()) demás: items.append ((new_key, valor)) return dict (elementos)
from collections.abc import MutableMapping def flatten(dictionary, parent_key='', separator='_'): items = [] for key, value in dictionary.items(): new_key = parent_key separator key if parent_key else key if isinstance(value, MutableMapping): items.extend(flatten(value, new_key, separator=separator).items()) else: items.append((new_key, value)) return dict(items)
& gt; & gt; & gt; Flatten ({'a': 1, 'c': {'a': 2, 'b': {'x': 5, 'y': 10}}, 'd': [1, 2, 3]}) {'A': 1, 'c_a': 2, 'c_b_x': 5, 'd': [1, 2, 3], 'c_b_y': 10}
Descargo de responsabilidad: Todos los recursos proporcionados provienen en parte de Internet. Si existe alguna infracción de sus derechos de autor u otros derechos e intereses, explique los motivos detallados y proporcione pruebas de los derechos de autor o derechos e intereses y luego envíelos al correo electrónico: [email protected]. Lo manejaremos por usted lo antes posible.
Copyright© 2022 湘ICP备2022001581号-3