18

我正在构建这个“工作服务器”模型。我想包含一个字段,该字段将保存该作业将在一周中的哪几天运行。最终在 UI 中,我希望用户能够拥有一系列他们可以选择的复选框(每天一个)。在我的模式中表示这种“星期几”数据的最佳方式是什么?

class Job(models.Model):
    name = models.CharField(max_length=32, unique=True)
    package = models.ForeignKey(Package)
    binary = models.ForeignKey(Binary)
    host = models.ForeignKey(Host)
    colo = models.ForeignKey(Location)
    group = models.ForeignKey(Group)
    type = models.ForeignKey(Type)
    start = models.TimeField()
    end = models.TimeField()
    days = ?
4

4 回答 4

25

您可能想要创建 DayOfTheWeek 字段类型,您可以通过各种方式对其进行改进。

此代码使用多语言工具自动翻译成当地语言。

#myFields.py
from django.utils.translation import ugettext as _

DAY_OF_THE_WEEK = {
    '1' : _(u'Monday'),
    '2' : _(u'Tuesday'),
    '3' : _(u'Wednesday'),
    '4' : _(u'Thursday'),
    '5' : _(u'Friday'),
    '6' : _(u'Saturday'), 
    '7' : _(u'Sunday'),
}

class DayOfTheWeekField(models.CharField):
    def __init__(self, *args, **kwargs):
        kwargs['choices']=tuple(sorted(DAY_OF_THE_WEEK.items()))
        kwargs['max_length']=1 
        super(DayOfTheWeekField,self).__init__(*args, **kwargs)

#models.py
import myFields
(..)
    dayOfTheWeek = myFields.DayOfTheWeekField()
(..)
于 2012-03-07T16:09:03.683 回答
22

像这样的东西会起作用。

#models.py
DAYS_OF_WEEK = (
    (0, 'Monday'),
    (1, 'Tuesday'),
    (2, 'Wednesday'),
    (3, 'Thursday'),
    (4, 'Friday'),
    (5, 'Saturday'),
    (6, 'Sunday'),
)

days = models.CharField(max_length=1, choices=DAYS_OF_WEEK

#forms.py
widgets = { 'days': forms.CheckboxSelectMultiple }

或保存多天

#models.py
class Days(models.Model):
    day = models.CharField(max_length=8)

days = models.ManyToManyField(Days)

#forms.py
widgets = { 'days': forms.CheckboxSelectMultiple }
于 2011-05-11T15:25:08.423 回答
3

如果您想要为每个复选框设置一个复选框,那么最简单的方法是为每个复选框创建 BooleanFields。如果您想将其存储为更复杂的值(例如逗号分隔列表或其他内容),请创建自己的小部件并使用 javascript,那么您可以走这条路。

于 2011-05-11T15:26:35.657 回答
0

刚刚实施django-weekday-field。效果很好!希望这可以帮助其他偶然发现这个问题的人

编辑:自 bitbucket repo 被删除以来更新了指向 pypi 的链接。

它自 2014 年以来一直没有更新,但查看代码是开始回答这个问题的好方法

于 2016-06-01T20:48:55.967 回答