这是部分算法逻辑问题(如何做),部分实施问题(如何做到最好!)。我正在与 Django 一起工作,所以我想我会与它分享。
在 Python 中,值得一提的是,该问题与how-do-i-use-pythons-itertoolsgroupby有点相关。
假设你有两个 Django 模型派生类:
from django.db import models
class Car(models.Model):
mods = models.ManyToManyField(Representative)
和
from django.db import models
class Mods(models.Model):
...
一个人如何获得一个汽车列表,按汽车和一组通用的 Mod 分组?
即我想像这样上课:
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' } },
]
我一直在想类似的东西:
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
但是,这不起作用,因为(可能还有其他原因) groupby 似乎没有按 mods 集分组。我猜必须对 mod_list 进行排序才能与 groupby 一起使用。总而言之,我相信那里有一些简单而优雅的东西,既具有启发性又具有启发性。
干杯&谢谢!