Система посещаемости в Django - PullRequest
0 голосов
/ 13 января 2020

Я работаю над системой посещаемости в Django. но я столкнулся с некоторой проблемой.

model.py

attendance_choices = (
    ('absent', 'Absent'),
    ('present', 'Present')
)


class AttendenceTable(models.Model):
    schedule_name = models.ForeignKey(ScheduleTable, on_delete=models.CASCADE, blank=True)
    RollNo = models.CharField(max_length=46, blank=True, null=True)
    student_name = models.TextField(blank=True, null=True)
    status = models.CharField(max_length=8, choices=attendance_choices, blank=True)

    def __str__(self):
        return self.RollNo

** views.py **



def take_attendance(request, id):
    schedule = get_object_or_404(ScheduleTable, pk=id)
    userlist = User.objects.filter(college = schedule.college).filter(is_student=True).filter(section=schedule.section)
    context = {
               "userlist":userlist,
               "schedule_name": schedule,
    }
    return render(request, "take.html", context )


def AttendanceStore(request, id):
    sch = get_object_or_404(ScheduleTable, pk=id)
    userlist = User.objects.all().filter(college=sch.college).filter(section=sch.section)
    attendance = OnlineAttendanceTable()
    insert_list = []
    for user in userlist:
        userstatus = request.POST.get(str(user.username))
        attendance.schedule = sch.name
        attendance.usn = user.username
        attendance.status = userstatus
        insert_list.append(attendance)
        print(insert_list)
        OnlineAttendanceTable.objects.bulk_create()

    return render(request, "submitattendance.html" )

result

enter image description here

Как на скриншоте, это репликация данных в модели, но мне нужны по одному на пользователя

предложите мне любую идею сделать систему посещаемости в Django

1 Ответ

0 голосов
/ 13 января 2020

Насколько я понимаю, у вас есть форма для посещения (я бы заполнил таблицу именами зачисленных учеников и флажком для каждого учащегося). Я предполагаю, что учитель заполняет форму с нынешними учениками и отправляет ее. При отправке вы должны обработать форму для обновления вашей базы данных.

Пример:

В следующем псевдокоде Я подробно опишу 3 модели, которые буду использовать:

1. ScheduledLecture(models.Model):
    subject -> CharField
    scheduled_date_time -> DateTimeField

2. Student(models.Model)
    name -> CharField
    enrolled_lectures -> ManyToManyField(ScheduledLecture)

3. Attendance(models.Model)
    student -> ForeignKey(Student)
    lectures_attended -> ManyToManyField(ScheduledLecture)

Когда вы читаете таблицу посещаемости из БД, вы можете фильтровать по лекциям и получать студентов, которые посещали.

...