如何限制用户在Django中选择年份范围内的日期?

4 投票
1 回答
6074 浏览
提问于 2025-04-16 11:54

models.py

class Completion(models.Model):
    start_date = models.DateField()
    end_date = models.DateField()
    batch = models.ForeignKey(Batch)
    topic = models.ForeignKey(Topic)

在上面的代码中,DateField() 会在管理后台生成一个日期选择工具,用户可以在这里选择合适的日期,或者手动在文本框中输入日期。不过,这里有几个问题:

  1. 我想限制用户只能选择2000年到2100年之间的日期。

  2. 当用户在文本框中手动输入日期时,系统会接受任何符合yy-mm-dd格式的日期。我需要一些验证,确保用户不能输入不存在的日期。

1 个回答

11

看看这个验证器吧!

首先,你需要定义一个验证器:

from django.core.exceptions import ValidationError

def validate_current_century(value):
    if value < 2000 or value > 2100:
        raise ValidationError(u'%s is not a valid year!' % value)

现在你可以在你的模型字段中使用它:

class Completion(models.Model):
    start_date = models.DateField(validators=[validate_current_century])
    end_date = models.DateField(validators=[validate_current_century])

也可以在表单字段中使用:

from django import forms

class MyForm(forms.Form):
    current_century_field = forms.DateField(validators=[validate_current_century])

更多详细信息可以在上面链接的文档中找到。

撰写回答