[英]Attendance system in Django
我正在 Django 中開發考勤系統。 但我面臨一些問題。
模型.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
** 視圖.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" )
結果
根據屏幕截圖,它正在復制模型中的數據,但我需要每個用戶一個數據
建議我在 Django 中制作考勤系統的任何想法
據我所知,你有一個表格來參加(我會用注冊學生的名字和每個學生的復選框填充一個表格)。 我假設老師用在場的學生填寫表格並提交。 提交時,您應該處理表單以更新您的數據庫。
在下面的偽代碼中,我詳細介紹了我將使用的 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)
當您從數據庫中讀取出勤表時,您可以按講座過濾,並獲得出席的學生。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.