简体   繁体   English

Django DateTimeField 时间戳值的格式无效。 它必须是 YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ] 格式

[英]Django DateTimeField Timestamp value has an invalid format. It must be in YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ] format

The environment is:环境是:

  • Django 4.0 (venv) Django 4.0 (venv)
  • Python 3.8 Python 3.8
  • Postgres 15 Postgres 15
  • Elementary OS 6.1基本操作系统 6.1

The initial model:初始model:

class MyModel(models.Model):
    other_field = models.BooleanField()
    created = models.DateTimeField(auto_now_add=True)
    updated = models.DateTimeField(auto_now=True)

Upon saving a new record ( without providing any value for "created" nor "updated" ) the result was:保存新记录后(不为“创建”或“更新”提供任何值)结果为:

django.core.exceptions.ValidationError: ['“1669827388000” value has an invalid format. It must be in YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ] format.']

Then I've followed some suggestions to do this:然后我遵循了一些建议来做到这一点:

class MyModel(models.Model):
    created = models.DateTimeField(editable=False)
    updated = models.DateTimeField(editable=False)

# Still doesnt work: It gets a timestamp
def save(self, *args, **kwargs):
    if not self.id:
        self.created = timezone.now()
    self.updated = timezone.now()
    return super(Token, self).save(*args, **kwargs)

The result was exactly the same (of course the timestamp's value changed).结果完全一样(当然时间戳的值改变了)。

I've tried variations with django.settings settings.USE_TZ from True to False & vice versa.我尝试了 django.settings settings.USE_TZTrueFalse的变体,反之亦然。

Traceback:追溯:

  Traceback (most recent call last):
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/django/core/handlers/exception.py", line 55, in inner
    response = get_response(request)
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/django/core/handlers/base.py", line 197, in _get_response
    response = wrapped_callback(request, *callback_args, **callback_kwargs)
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/django/views/decorators/csrf.py", line 54, in wrapped_view
    return view_func(*args, **kwargs)
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/django/views/generic/base.py", line 103, in view
    return self.dispatch(request, *args, **kwargs)
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/rest_framework/views.py", line 509, in dispatch
    response = self.handle_exception(exc)
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/rest_framework/views.py", line 469, in handle_exception
    self.raise_uncaught_exception(exc)
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/rest_framework/views.py", line 480, in raise_uncaught_exception
    raise exc
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/rest_framework/views.py", line 506, in dispatch
    response = handler(request, *args, **kwargs)
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/rest_framework/decorators.py", line 50, in handler
    return func(*args, **kwargs)
  File "/home/PROJECT_NAME/app_name/views.py", line 39, in register_new_email
    new_token.save()
  File "/home/PROJECT_NAME/app_name/models.py", line 170, in save
    return super(Token, self).save(*args, **kwargs)
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/django/db/models/base.py", line 812, in save
    self.save_base(
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/django/db/models/base.py", line 863, in save_base
    updated = self._save_table(
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/django/db/models/base.py", line 1006, in _save_table
    results = self._do_insert(
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/django/db/models/base.py", line 1047, in _do_insert
    return manager._insert(
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/django/db/models/manager.py", line 85, in manager_method
    return getattr(self.get_queryset(), name)(*args, **kwargs)
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/django/db/models/query.py", line 1790, in _insert
    return query.get_compiler(using=using).execute_sql(returning_fields)
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/django/db/models/sql/compiler.py", line 1659, in execute_sql
    for sql, params in self.as_sql():
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/django/db/models/sql/compiler.py", line 1583, in as_sql
    value_rows = [
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/django/db/models/sql/compiler.py", line 1584, in <listcomp>
    [
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/django/db/models/sql/compiler.py", line 1585, in <listcomp>
    self.prepare_value(field, self.pre_save_val(field, obj))
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/django/db/models/sql/compiler.py", line 1523, in prepare_value
    value = field.get_db_prep_save(value, connection=self.connection)
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/django/db/models/fields/__init__.py", line 925, in get_db_prep_save
    return self.get_db_prep_value(value, connection=connection, prepared=False)
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/django/db/models/fields/__init__.py", line 1582, in get_db_prep_value
    value = self.get_prep_value(value)
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/django/db/models/fields/__init__.py", line 1560, in get_prep_value
    value = super().get_prep_value(value)
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/django/db/models/fields/__init__.py", line 1433, in get_prep_value
    return self.to_python(value)
  File "/home/PROJECT_NAME/.venv/lib/python3.8/site-packages/django/db/models/fields/__init__.py", line 1542, in to_python
    raise exceptions.ValidationError(
django.core.exceptions.ValidationError: ['“1669827388000” value has an invalid format. It must be in YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ] format.']

Thanks in advance for any suggestion!在此先感谢您的任何建议!

EDIT编辑

The insertion is done in a view I just don't insert anything at the DateTime fields of the model & django -supposedly- handles it automatically:插入是在一个view中完成的,我只是不在 model 和 django 的DateTime字段中插入任何内容 - 应该会自动处理它:

@api_view(['GET'])
def dummy_view(request):
    new_record = MyModel(
        other_field=True
    )
    new_token.save()

As @AdrianKlaver mentioned, a conversion from ms should take place first.正如@AdrianKlaver提到的,应该首先从 ms 进行转换。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

相关问题 [u&quot;&#39;&#39; 值的格式无效。它必须是 YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ] 格式。&quot;] - [u"'' value has an invalid format. It must be in YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ] format."] jquery 日期值的格式无效。 保存到 dajngo 时它必须在 YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ] 中? - jquery date value has an invalid format. It must be in YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ] when saving to dajngo? 如何修复“django.core.exceptions.ValidationError: [“'' value has an invalid format. It must be in YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ] format.”]” - How to fix "django.core.exceptions.ValidationError: [“'' value has an invalid format. It must be in YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ] format.”]" [&quot;&#39;%(value)s&#39; 值的格式无效。它必须是 YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ] 格式。&quot;] 如果我检查 full_clean 会显示() - ["'%(value)s' value has an invalid format. It must be in YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ] format."] will show up if I check for full_clean() [u&#39;以YYYY-MM-DD HH:MM [:ss [.uuuuuu]]格式输入有效日期/时间的验证错误。&#39;] - ValidationError at [u'Enter a valid date/time in YYYY-MM-DD HH:MM[:ss[.uuuuuu]] format.'] Django:表单验证错误:[&#39;“”值的日期格式无效。 它必须是 YYYY-MM-DD 格式。&#39;] - Django: Form ValidationError: ['“” value has an invalid date format. It must be in YYYY-MM-DD format.'] ValidationError: [“'' 值的日期格式无效。 它必须是 YYYY-MM-DD 格式。”] 在 django - ValidationError: [“'' value has an invalid date format. It must be in YYYY-MM-DD format.”] in django Django 中的日期和时间解析错误 [&quot;&#39;Tue, 02 Jul 2019 08:11:45 +0530&#39; value has an invalid format. in YYYY-MM-DD HH:MM[:ss[.uuu]][TZ]格式。”] - Error in date and time parsing in Django ["'Tue, 02 Jul 2019 08:11:45 +0530' value has an invalid format. in YYYY-MM-DD HH:MM[:ss[.uuu]][TZ] format."] django:value的日期格式无效。 它必须是YYYY-MM-DD格式 - django: value has an invalid date format. It must be in YYYY-MM-DD format [u“ 0”值的日期格式无效。 它必须为YYYY-MM-DD格式。”] - [u“'0' value has an invalid date format. It must be in YYYY-MM-DD format.”]
 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM