使用django admin以每周为基础的数据库填充数据库

时间:2009-11-08 02:42:23

标签: django django-admin data-entry

我正在构建一个小型django应用程序,以便管理商店员工名单。 员工是自由职业者,他们每周都有几乎固定的时间表,并且可能在任何工作日/时间要求额外的时间。

我是python和django的新手,我正在使用django管理员。

当我“手动”添加“Turno”(工作任务时,我不确定,它可能是英语中的“Shift”)时,一切都工作得很公平(对我而言)。

我需要一些方法通过django管理员添加每周固定的Turnos(一次性全部,而不是“手动”),例如设置工作日,开始和结束时间以及停止日期2(或者提前三个月......怎么样?

任何类型的帮助都会很棒,我不是要求你们让人们履行我的职责。

这是我的models.py:

from django.db import models
from django.contrib.auth.models import User
import datetime

class Dia(models.Model):
fecha = models.DateField(unique=True)

    class Meta:
        ordering = ['fecha']

    def __unicode__(self):
        return (self.fecha.strftime('%A %d de %b de \'%y'))

class Turno(models.Model):
    dia = models.ForeignKey(Dia)
    perfil_usuario = models.ForeignKey(User, verbose_name="Usuario")
    comienza = models.TimeField()
    finaliza = models.TimeField()
    comentarios = models.TextField(blank=True, null=True)

    def __unicode__(self):
        return self.dia.fecha.strftime('%A %d de %b de \'%y') + ' - ' + self.perfil_usuario.username

这是我的admin.py

from roquen.horarios.models import Turno, Dia
from django.contrib.auth.models import User
from django.contrib import admin
from django import forms

admin.site.register(Dia)

class TurnoAdminForm(forms.ModelForm):
    class Meta:
        model = Turno

    def clean_finaliza(self):
        data = self.cleaned_data['finaliza']
        if data <= self.cleaned_data['comienza']:
            raise forms.ValidationError('La hora de fin debe ser posterior a la de comienzo')
        return data

class TurnoAdmin(admin.ModelAdmin):
    form = TurnoAdminForm
    list_display = ['dia', 'perfil_usuario', 'comienza', 'finaliza']

admin.site.register(Turno, TurnoAdmin)

1 个答案:

答案 0 :(得分:1)

您实际上是在询问数据库架构问题。您当前的解决方案有两个概念:工人和班次,以便“班次”是特定日期的时间间隔。此模型不再有效。

要引入预定的班次,您的问题域必须封装“shift”一词的两个概念,并且两者之间的区别对于解决方案至关重要:

  1. “shift”是
  2. 的时间间隔
  3. “班次实例”是特定日期
  4. 的时间间隔

    因此,通过将“shift”重命名为反映特定日期发生的事实来相应地更改模型。然后创建一个更一般地反映轮班的新模型:它发生在一周中的某一天,而不是任何特定的日期。

    因此,您的工人可以与本周发生的某些班次相关联,但可以随意改变他们的实际班次。要将工作人员分配到特定日期的特定班次,请创建班次实例。

    您可以创建一个流程,定期(每周)循环所有轮班,并为下周创建轮班实例。