Esta es una pregunta de parte de algoritmo lógica (cómo hacerlo), pregunta de implementación de parte (cómo hacerlo mejor!). Estoy trabajando con Django, así que pensé en compartir con eso.Django/Python - Agrupación de objetos por conjunto común de una relación de muchos a muchos
En Python, vale la pena mencionar que el problema está relacionado con un poco how-do-i-use-pythons-itertoolsgroupby.
supongamos que usted es dado dos clases de derivados de los modelos de Django:
from django.db import models
class Car(models.Model):
mods = models.ManyToManyField(Representative)
y
from django.db import models
class Mods(models.Model):
...
¿Cómo se puede obtener una lista de los coches, agrupados por coches con un conjunto común de Mods?
I.e. Quiero conseguir un likeso clase:
Cars_by_common_mods = [
{ mods: { 'a' }, cars: { 'W1', 'W2' } },
{ mods: { 'a', 'b' }, cars: { 'X1', 'X2', 'X3' }, },
{ mods: { 'b' }, cars: { 'Y1', 'Y2' } },
{ mods: { 'a', 'b', 'c' }, cars: { 'Z1' } },
]
He estado pensando en algo como:
def cars_by_common_mods():
cars = Cars.objects.all()
mod_list = []
for car in cars:
mod_list.append({ 'car': car, 'mods': list(car.mods.all()) }
ret = []
for key, mods_group in groupby(list(mods), lambda x: set(x.mods)):
ret.append(mods_group)
return ret
Sin embargo, que no funciona debido a que (quizá entre otras razones) la GroupBy no lo hace parece agruparse por los conjuntos de modificaciones. Supongo que la lista_de_mod debe ser ordenada para que funcione con groupby. Todo para decir, estoy seguro de que hay algo simple y elegante por ahí que será a la vez instructivo y esclarecedor.
Saludos & gracias!
Gracias por la respuesta. Miré reagrupar, pero el problema (no declarado) es que hay más lógica que hacer después de las agrupaciones iniciales. Es un buen consejo, sin embargo; veré si puedo diseñarlo para reagruparlo. –