Tengo un problema extraño al usar itertools.groupby
para agrupar los elementos de un conjunto de preguntas. Tengo un modelo Resource
:itertools.groupby en una plantilla django
from django.db import models
TYPE_CHOICES = (
('event', 'Event Room'),
('meet', 'Meeting Room'),
# etc
)
class Resource(models.Model):
name = models.CharField(max_length=30)
type = models.CharField(max_length=5, choices=TYPE_CHOICES)
# other stuff
Tengo un par de recursos en mi base de datos SQLite:
>>> from myapp.models import Resource
>>> r = Resource.objects.all()
>>> len(r)
3
>>> r[0].type
u'event'
>>> r[1].type
u'meet'
>>> r[2].type
u'meet'
Así que si agrupo por tipo, yo, naturalmente, conseguir dos tuplas:
>>> from itertools import groupby
>>> g = groupby(r, lambda resource: resource.type)
>>> for type, resources in g:
... print type
... for resource in resources:
... print '\t%s' % resource
event
resourcex
meet
resourcey
resourcez
Ahora tengo la misma lógica en mi opinión:
class DayView(DayArchiveView):
def get_context_data(self, *args, **kwargs):
context = super(DayView, self).get_context_data(*args, **kwargs)
types = dict(TYPE_CHOICES)
context['resource_list'] = groupby(Resource.objects.all(), lambda r: types[r.type])
return context
Pero cuando iterar sobre esto en mi plantilla, algunos recursos faltan:
<select multiple="multiple" name="resources">
{% for type, resources in resource_list %}
<option disabled="disabled">{{ type }}</option>
{% for resource in resources %}
<option value="{{ resource.id }}">{{ resource.name }}</option>
{% endfor %}
{% endfor %}
</select>
Esto hace que:
Estoy pensando en alguna manera los subiterators se repiten a lo largo ya, pero no estoy seguro de cómo podría pasar esto.
(Usando python 2.7.1, Django 1.3).
(EDIT: Si alguien lee esto, me gustaría recomendar el uso de la incorporada en el regroup
template tag en lugar de utilizar groupby
.)
Gracias por investigar; Lo intenté con ~ 10 recursos y tenía como máximo un recurso por grupo - lo arreglé poblando el contexto con '(t, list (r)) para t, r en groupby (...)' –
Sí, el el iterador se está iterando previamente, Django convierte el iterador en una lista sin iterar a través de los elementos agrupados. He agregado una explicación en una respuesta separada. –