Python: agrupación de suma en la lista de diccionarios

A veces, mientras trabajamos con los diccionarios de Python, podemos tener un problema en el que necesitamos agrupar los diccionarios según una clave específica y realizar la suma de ciertas claves mientras agrupamos el valor de una clave similar. Este es un problema peculiar, pero puede tener aplicaciones en dominios como el desarrollo web. Analicemos una determinada forma en que se puede realizar esta tarea.

Entrada: test_list = [{‘geeks’: 10, ‘mejor’: 8, ‘Gfg’: 6}, {‘geeks’: 12, ‘mejor’: 11, ‘Gfg’: 4}]
Salida: {4: {‘geeks’: 12, ‘mejor’: 11}, 6: {‘geeks’: 10, ‘mejor’: 8}}

Entrada: test_list = [{‘CS’: 14, ‘mejor’: 9, ‘geeks’: 7, ‘Gfg’: 14}]
Salida: {14: {‘mejor’: 9, ‘geeks’: 7}}

Método n.º 1: Usar bucle
Esta es una forma de fuerza bruta en la que se puede realizar esta tarea. En esto, recorremos manualmente cada clave del diccionario y realizamos la agrupación requerida de acuerdo con la clave y construimos el diccionario agrupado y sumado requerido.

# Python3 code to demonstrate working of 
# Summation Grouping in Dictionary List
# Using loop
  
# initializing list
test_list = [{'Gfg' :  1, 'id' : 2, 'best' : 8, 'geeks' : 10}, 
             {'Gfg' :  4, 'id' : 4, 'best':  10, 'geeks' : 12}, 
             {'Gfg' :  4, 'id' : 8, 'best':  11, 'geeks' : 15}]
  
# printing original list
print("The original list is : " + str(test_list))
  
# initializing group key 
grp_key = 'Gfg'
  
# initializing sum keys 
sum_keys = ['best', 'geeks']
  
# Summation Grouping in Dictionary List
# Using loop
res = {}
for sub in test_list:
    ele = sub[grp_key]
    if ele not in res:
        res[ele] = {x: 0 for x in sum_keys}
    for y in sum_keys:
        res[ele][y] += int(sub[y])
  
# printing result 
print("The grouped list : " + str(res)) 
Producción :

La lista original es: [{‘geeks’: 10, ‘id’: 2, ‘best’: 8, ‘Gfg’: 1}, {‘geeks’: 12, ‘id’: 4, ‘best’: 10 , ‘Gfg’: 4}, {‘geeks’: 15, ‘id’: 8, ‘best’: 11, ‘Gfg’: 4}]
La lista agrupada: {1: {‘geeks’: 10, ‘best ‘: 8}, 4: {‘geeks’: 27, ‘mejor’: 21}}

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

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *