【问题标题】:Attendance system in DjangoDjango中的考勤系统
【发布时间】: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


【解决方案1】:

据我了解,您有一个出勤表格(我会在一个表格中填充已注册学生的姓名和每个学生的复选框)。我假设老师用现在的学生填写表格并提交。 在提交时,您应该处理表单以更新您的数据库。

一个例子:

在下面的伪代码中,我详细介绍了我将使用的 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)
    

当您从数据库中读取出勤表时,您可以按讲座过滤,并获取参加过的学生。

【讨论】:

  • 您可以将您的解决方案作为问题的答案发布,这样问题就会被标记为已回答。请尝试使用代码 sn-ps 的编辑器。特别是对于 python,因为缩进是关键。谢谢!
猜你喜欢
  • 2019-10-12
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2016-12-17
  • 2020-11-11
  • 1970-01-01
  • 2021-02-19
  • 1970-01-01
相关资源
最近更新 更多