老问题,我知道。但是我仍然找不到可行的解决方案,因此我可能错过了一些显而易见的事情。这是我的表格
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的事实,该格式具有显式参数,足以使验证者理解什么?我想念什么?
欢迎任何见识
答案 0 :(得分:1)
角色\xa0
与iso8859-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
模块。