Django DateField格式无法验证并保存到模型

时间:2018-11-22 20:59:00

标签: django datetime django-models django-forms date-format

老问题,我知道。但是我仍然找不到可行的解决方案,因此我可能错过了一些显而易见的事情。这是我的表格

class AddPatientForm(forms.Form):
    last_name = forms.CharField(label='Nom', max_length=40)
    first_name = forms.CharField(label='Prénom', max_length=40)
    birthday = forms.DateField(label='date de naissance',
         widget=forms.DateInput(format='%d/%m/%Y',attrs={'placeholder': '31/03/1989'}),
         input_formats=['%d/%m/%Y',])

它遵循这种格式约定,并且必须这样做。这是我的模型

class Patients(models.Model):
    first_name = models.CharField(max_length=40)
    last_name = models.CharField(max_length=40)
    birth_date = models.DateField()
    inscription = models.DateTimeField(auto_now_add=True)

这是我在 setting.py 中尝试解决的问题

DATE_FORMAT = "d-m-Y"
DATE_INPUT_FORMATS = ['%d-%m-%Y']
USE_L10N = False

尽管如此,我仍然遇到同样的问题:

form = AddPatientForm(request.POST)
    if form.is_valid():
        form.clean()
        d = Patients(first_name= form["first_name"].value(), 
            last_name= form["last_name"].value(),
            birth_date= form["birthday"].value())
        d.save()
>>>>["Le format de date de la valeur «\xa027/10/1987\xa0» n'est pas valide. Le format correct est AAAA-MM-JJ."]

[免责声明]我不是要覆盖模型格式约定,我知道日期“ 如何真正存储在数据库中”的问题无关紧要(不同从一个DBMS到另一个DBMS; django模型对此是不可知的)。但这就是***与如此简单的任务作斗争的关键。我为什么不能:

  • 对表单和模型使用不同的格式吗?
  • 以某种方式覆盖此参数?

不是一个具有显式格式的DateField的事实,该格式具有显式参数,足以使验证者理解什么?我想念什么?

欢迎任何见识

1 个答案:

答案 0 :(得分:1)

角色\xa0iso8859-1编码有关。这是一个示例:

>>> a = b'\xa027/10/1987\xa0'
>>> a.decode('iso8859-1').strip()
'27/10/1987'

因此,在您的问题中,如果birth_date= form["birthday"].value()bytes对象,则需要先以有效日期格式的常规字符串对其进行解码,以进行进一步操作:

birth_date = form["birthday"].value().decode('iso8859-1')

否则,如果birth_date的类型是字符串,则可以轻松做到:

birth_date = form["birthday"].value().replace(u'\xa0', u'')

然后,为了将日期存储在数据库中,您需要一个有效的datetime对象。您可以将字符串转换为有效的Python日期时间对象,例如以下示例:

>>> from datetime import datetime
>>> datetime.strptime('27/10/1987', '%d/%m/%Y')
datetime.datetime(1987, 10, 27, 0, 0)

奖金:如果您需要一个已知的日期时间对象,请考虑使用pytz模块。