A veces, mientras trabajamos con registros de Python, podemos tener problemas en los que tenemos datos en forma de Listas de lista y necesitamos asignar ciertos elementos como claves y ciertos como valores para formar un diccionario. Este tipo de aplicación puede ocurrir en dominios de datos. Analicemos ciertas formas en que se puede realizar esta tarea.
Método n.º 1: Uso del bucle
Esta es la forma bruta en la que realizamos esta tarea. En esto, iteramos a través de las listas formando pares de valores clave de acuerdo con el corte requerido.
# Python3 code to demonstrate working of # Convert Lists of List to Dictionary # Using loop # initializing list test_list = [['a', 'b', 1, 2], ['c', 'd', 3, 4], ['e', 'f', 5, 6]] # printing original list print("The original list is : " + str(test_list)) # Convert Lists of List to Dictionary # Using loop res = dict() for sub in test_list: res[tuple(sub[:2])] = tuple(sub[2:]) # printing result print("The mapped Dictionary : " + str(res))
La lista original es: [[‘a’, ‘b’, 1, 2], [‘c’, ‘d’, 3, 4], [‘e’, ‘f’, 5, 6]
] Diccionario: {(‘c’, ‘d’): (3, 4), (‘e’, ‘f’): (5, 6), (‘a’, ‘b’): (1, 2) }
Método #2: Uso de la comprensión del diccionario
Esta es otra forma más en la que se puede realizar esta tarea. Esto es similar al método anterior, solo una alternativa de una sola línea.
# Python3 code to demonstrate working of # Convert Lists of List to Dictionary # Using dictionary comprehension # initializing list test_list = [['a', 'b', 1, 2], ['c', 'd', 3, 4], ['e', 'f', 5, 6]] # printing original list print("The original list is : " + str(test_list)) # Convert Lists of List to Dictionary # Using dictionary comprehension res = {tuple(sub[:2]): tuple(sub[2:]) for sub in test_list} # printing result print("The mapped Dictionary : " + str(res))
La lista original es: [[‘a’, ‘b’, 1, 2], [‘c’, ‘d’, 3, 4], [‘e’, ‘f’, 5, 6]
] Diccionario: {(‘c’, ‘d’): (3, 4), (‘e’, ‘f’): (5, 6), (‘a’, ‘b’): (1, 2) }
Publicación traducida automáticamente
Artículo escrito por manjeet_04 y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA