在Django模型中验证日期和日期时间间隔的最佳解决方案是什么?
这是我的模特:
class PriceOption(Model):
from_datetime = DateTimeField(verbose_name=_('from datetime'))
to_datetime = DateTimeField(verbose_name=_('to datetime'))
from_time = TimeField(verbose_name=_('from time'))
to_time = TimeField(verbose_name=_('to time'))
我需要确保from_datetime在to_datetime之前发生,而对于from_time和to_time则相同。
我应该覆盖保存方法吗?还是以某种方式验证?
我看到Postgres有Date和DateTime范围字段。这只会解决第一对字段。
答案 0 :(得分:1)
最好使用表单来验证时间范围,表单已经内置了函数clean()
以满足您的需求:
class PriceOptionForm(forms.ModelForm):
# some normal ModelForm setup goes here
def clean(self):
cleaned_data = super(PriceOptionForm, self).clean()
from_time = cleaned_data.get("from_time")
end_time = cleaned_data.get("end_time")
if from_time and end_time:
if end_time < from_time:
raise forms.ValidationError("End time cannot be earlier than start time!")
return cleaned_data