首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在Django中计数和显示关系ManyToMany中的对象

如何在Django中计数和显示关系ManyToMany中的对象
EN

Stack Overflow用户
提问于 2009-11-21 05:57:48
回答 2查看 4.4K关注 0票数 3

我有一个包含新闻和分类的简单模型:

代码语言:javascript
复制
class Category(models.Model):
    name = models.CharField()
    slug = models.SlugField()

class News(models.Model):
    category = models.ManyToManyField(Category)
    title = models.CharField()
    slug = models.SlugField()
    text = models.TextField()
    date = models.DateTimeField()

我想要计算每个类别的新闻,并将其显示在网站上,如下所示:

代码语言:javascript
复制
Sport (5)
School (4)
Films (6)
Computer (2)
etc...

我该怎么做呢??

谢谢!

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2009-11-21 06:03:23

查看Django 1.1中的annotate()函数。

http://docs.djangoproject.com/en/dev/topics/db/aggregation/#topics-db-aggregation

示例(来自上面的URL ):

代码语言:javascript
复制
>>> q = Book.objects.annotate(num_authors=Count('authors'))
>>> q[0].num_authors
2
>>> q[1].num_authors
1
票数 7
EN

Stack Overflow用户

发布于 2013-08-29 23:44:11

非常简单:

代码语言:javascript
复制
>>> for category in Category.objects.all():
...     print category.name, category.news_set.count()
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1773504

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档