Как считать объекты модели в Django
Я пытаюсь сделать сайт по управлению студентами на Django. Теперь я хочу подсчитать, сколько учеников в одном классе и отобразить это число на моем сайте. Как я могу это сделать? Моя модель:
from django.db import models
import uuid
from django.core.validators import MaxValueValidator,
MinValueValidator
# Create your models here.
class Student(models.Model):
name = models.CharField(max_length=150)
roll = models.UUIDField(default=uuid.uuid4, unique=True,
primary_key=True, editable=False)
father_name = models.CharField(max_length=150)
mother_name = models.CharField(max_length=150)
phone_number = models.IntegerField(validators=
[MaxValueValidator(99999999999)])
grade = models.ForeignKey('grade', on_delete=models.CASCADE )
def __str__(self):
return self.name
class Grade(models.Model):
grade_name = models.IntegerField(validators=
[MaxValueValidator(10), MinValueValidator(1)])
id = models.UUIDField(default=uuid.uuid4, unique=True,
primary_key=True, editable=False)
def __str__(self):
return self.grade
Вы можете использовать filter()
затем count()
:
first_grade_students = Student.objects.filter(grade__grade_name =1).count()
Если вам нужно сгруппировать каждый класс без какой-либо фильтрации, с помощью следующего кода он сгруппирует подсчеты каждой группы и вернет их в виде dict
from django.db.models import Count
Student.objects.all().order_by('id').values('grade__grade_name').annotate(count=Count('id', distinct=True))
если вы хотите отфильтровать класс, следующий код вернет количество учеников в начальной школе
Student.objects.filter(grade__grade_name=elementary).count()
Используйте django.db.models Count
следующим образом :
from django.db.models import Count
q = Grade.objects.annotate(nb_students=Count('student'))
Чтобы получить доступ к количеству учащихся в классе, выполните следующие действия:
for grade in q:
print(grade.nb_students)