首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >获取对象的计数

获取对象的计数
EN

Stack Overflow用户
提问于 2014-12-10 12:21:30
回答 3查看 94关注 0票数 0

我想对所有的医生进行专业化计数,并将其显示在管理面板中。

这是模型

代码语言:javascript
复制
class Doctor(models.Model):
    name = models.CharField(max_length=1300)
    specialization = models.ForeignKey(Specialization)
    clinic = models.ForeignKey(Clinic)

class Specialization(models.Model):
    name = models.CharField(max_length=30)

例如,我想展示如下:

皮肤科医生: 10人

眼科医生: 15人

我对Django非常陌生,不知道该怎么做。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2014-12-10 12:44:28

不要使用obj.doctor_set.count()配方。将对每个专门化记录调用此方法。

将单个SQL查询与聚合一起使用:

代码语言:javascript
复制
# admin.py
from django.contrib import admin
from django.db.models import Count
from app.models import Specialization

class SpecializationAdmin(admin.ModelAdmin):

    list_display = ['name', 'doctor_count_display']

    def get_queryset(self, request):
        qs = super(SpecializationAdmin, self).get_queryset(request)
        return qs.annotate(doctor_count=Count('doctor')).order_by('-doctor_count')

    def doctor_count_display(self, obj):
        return obj.doctor_count
    doctor_count_display.short_description = 'Number of doctors'
    doctor_count_display.admin_order_field = 'doctor_count'

admin.site.register(Specialization, SpecializationAdmin)
票数 1
EN

Stack Overflow用户

发布于 2014-12-10 12:34:08

您可以以这样的方式完成这一任务,例如:

代码语言:javascript
复制
#admin.py
class SpecializationAdmin(admin.ModelAdmin):
    list_display = ('get_count',)
    def get_count(self, obj):
        return u"{}: {}".format(obj.name, obj.doctor_set.count())
    get_count.short_description = "Number of Doctors"

并注册如下:

代码语言:javascript
复制
# also in admin.py
admin.site.register(Specialization, SpecializationAdmin)

不要忘记将Specialization模型导入到admin.py

票数 1
EN

Stack Overflow用户

发布于 2014-12-10 12:34:01

您需要了解有关查询Django查询的信息

为了显示皮肤科医生的人数:

代码语言:javascript
复制
Doctor.objects.filter(specialization__name="Dermatologist").count()

显示眼科医生的人数

代码语言:javascript
复制
Doctor.objects.filter(specialization__name="Ophthalmologist").count()
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27400887

复制
相关文章

相似问题

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