【发布时间】:2020-01-13 07:42:17
【问题描述】:
我正在 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" )
结果
根据屏幕截图,它正在复制模型中的数据,但我需要每个用户一个数据
建议我在 Django 中制作考勤系统
【问题讨论】:
-
如果将
userlist更改为userlist = User.objects.filter(college = schedule.college).filter(is_student=True).filter(section=schedule.section).distinct()会怎样? -
OnlineAttendanceTable.objects.bulk_create()没有多大意义,因为您将在这里批量创建 no 元素。
标签: python html django forms time-and-attendance