1

在我的模型中有两个类:

class PageCategory(models.Model):
    name = models.CharField(max_length=256)
    slug = models.CharField(max_length=256, default='')

class Page(models.Model):
    title = models.CharField(max_length=256)
    slug = models.CharField(max_length=256)
    categories = models.ManyToManyField(PageCategory, related_name='page_categories', null=True, blank=True)

我正在尝试检索(a)要查看的一个页面,以及(b)属于该页面所属的相同类别的所有其他页面,以便也列出它们。

这就是我正在做的(这是错误的):

def pageView(request, page_slug):
    page = get_object_or_404(Page, slug=unicode(page_slug))
    pages = Page.objects.filter(displayable=True, categories__in=page.categories).exclude(pk=page.id).order_by('-timestamp')

我总是得到一个'ManyRelatedManager' object is not iterable

应该怎么做?

4

1 回答 1

4

page.categories是一个ManyRelatedManager而不是一个列表categories(这是__in检查所必需的)。所以需要指定page.categories.all()过滤__in

您的查询更改为:

pages = Page.objects.filter(displayable=True, 
        categories__in=page.categories.all()).
        exclude(pk=page.id).order_by('-timestamp')
于 2012-09-09T07:08:12.873 回答