尝试创建对象元组会创建一个对象和一个查询集

时间:2011-06-26 15:06:40

标签: python django django-templates django-queryset

我需要在模板中迭代一个元组,但是从我构建的代码中我得到了一个对象(相册)和一个查询集(照片)的元组。问题是如何在模板中迭代它们?

模型:

class Album(models.Model):
    title = models.CharField('כותרת', max_length=100, db_index=True)
    created = models.DateTimeField('תאריך פרסום', auto_now_add=True)
    creator = models.ForeignKey(User, related_name='galleries_creator', verbose_name='נכתב ע"י')

class Photo(models.Model):
    title = models.CharField('כותרת', max_length=100)
    album = models.ForeignKey(Album, verbose_name='שייך לאלבום')
    photo = models.ImageField('תמונה', blank=True, upload_to=get_image_path)
    photo_mid = models.ImageField('תמונה בינונית', blank=True, upload_to='images/galleries/mid/', editable=False)
    photo_thumb = models.ImageField('תמונה קטנה', blank=True, upload_to='images/galleries/thumbs/', editable=False)
    created = models.DateTimeField('תאריך פרסום', auto_now_add=True)
    is_landscape = models.NullBooleanField(blank=True, verbose_name='האם תמונת לנדסקייפ', editable=False)

查看:

def index(request):
    albums = Album.objects.all().order_by('?')[:10]
    album_list = []
    for album in albums:
        album_list.append((album, Photo.objects.filter(album=album).order_by('?')[:1]))
    return render_to_response('galleries/index.html',{'albums':album_list},  context_instance=RequestContext(request))

模板:

{% for album, photo in albums %}
    <div class="polaroid" id="picture_{{ forloop.counter }}">
        <img src="{{ MEDIA_URL }}{{ photo.photo }}" alt="Picture #{{ forloop.counter }}" />
        <p class="caption"><p class="title">אלבום {{ forloop.counter }}</p><p>{{ album.creator.first_name }} {{ album.creator.last_name }}</p>
    </div>
{% endfor %}

正如我所看到的,我不能做photo.photo,因为照片是一个列表,而不是一个对象,我真的不想为元组中的每张照片做一个for循环(只有一张照片,所以这只是浪费)。

断言False album_list返回:

[(<Album: אלבום שני - ממשק מנהל>, [<Photo: אלבום 2 תמונה 2>]), (<Album: אלבום ראשון - ממשק מנהל>, [<Photo: אלבום 1 תמונה 7>]), (<Album: אלבום  נתן>, [<Photo: נסיון 4>])]

我可以在我的视图或模板中做些什么来解决这个问题?

2 个答案:

答案 0 :(得分:3)

如果您追逐的每张专辑只有一张照片,那么为什么要对查询集进行切片?只需使用索引获取第一个:

album_list.append((album, Photo.objects.filter(album=album).order_by('?')[0]))

答案 1 :(得分:0)

好吧,现在,使用内部for循环来解决这个问题,它显然有效,但我会很高兴听到任何其他建议,如果可能的话,以更有效的方式做到这一点......

<img src="{% for p in photo %}{{ MEDIA_URL }}{{ p.photo }}{% endfor %}" alt="Picture #{{ forloop.counter }}" />

10x: - )