首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >Django在创建模型时需要类似字符串或字节的对象

Django在创建模型时需要类似字符串或字节的对象
EN

Stack Overflow用户
提问于 2018-06-11 08:52:33
回答 1查看 3K关注 0票数 0

我有一个模型,我正在尝试创建一个新的实例。然而,当我运行基本的create命令时,我得到了一个错误。C.objects.create()。我仍然可以通过管理员创建一个实例,但似乎不能在它之外创建。

代码运行:

代码语言:javascript
复制
qs_a = A.objects.all().first()
qs_b = B.objects.all().first()
C.objects.create(a=qs_a, b=qs_b)

模型

代码语言:javascript
复制
class C(models.Model):
    a                    = models.ForeignKey(A, blank=True, default=False)
    b                    = models.ForeignKey(B, blank=True, default=False)
    the_id               = models.CharField(max_length=120, blank=True) # AB31DE3
    status               = models.CharField(max_length=120, default='initiated', choices=STATUS_CHOICES)
    start_date           = models.DateField(default=False, blank=True, null=True)
    end_date             = models.DateField(default=False, blank=True, null=True)
    ...

    updated              = models.DateTimeField(auto_now=True)
    timestamp            = models.DateTimeField(auto_now_add=True)

堆栈跟踪:

代码语言:javascript
复制
>> C.objects.create(a=qs_a, b=qs_b)
Traceback (most recent call last):
  File "<console>", line 1, in <module>
  File "C:\myApp\lib\site-packages\django\db\models\manager.py", line 85, in manager_method
    return getattr(self.get_queryset(), name)(*args, **kwargs)
  File "C:\myApp\lib\site-packages\django\db\models\query.py", line 394, in create
    obj.save(force_insert=True, using=self.db)
  File "C:\myApp\lib\site-packages\django\db\models\base.py", line 807, in save
    force_update=force_update, update_fields=update_fields)
  File "C:\myApp\lib\site-packages\django\db\models\base.py", line 837, in save_base
    updated = self._save_table(raw, cls, force_insert, force_update, using, update_fields)
  File "C:\myApp\lib\site-packages\django\db\models\base.py", line 923, in _save_table
    result = self._do_insert(cls._base_manager, using, fields, update_pk, raw)
  File "C:\myApp\lib\site-packages\django\db\models\base.py", line 962, in _do_insert
    using=using, raw=raw)
  File "C:\myApp\lib\site-packages\django\db\models\manager.py", line 85, in manager_method
    return getattr(self.get_queryset(), name)(*args, **kwargs)
  File "C:\myApp\lib\site-packages\django\db\models\query.py", line 1076, in _insert
    return query.get_compiler(using=using).execute_sql(return_id)
  File "C:\myApp\lib\site-packages\django\db\models\sql\compiler.py", line 1106, in execute_sql
    for sql, params in self.as_sql():
  File "C:\myApp\lib\site-packages\django\db\models\sql\compiler.py", line 1059, in as_sql
    for obj in self.query.objs
  File "C:\myApp\lib\site-packages\django\db\models\sql\compiler.py", line 1059, in <listcomp>
    for obj in self.query.objs
  File "C:\myApp\lib\site-packages\django\db\models\sql\compiler.py", line 1058, in <listcomp>
    [self.prepare_value(field, self.pre_save_val(field, obj)) for field in fields]
  File "C:\myApp\lib\site-packages\django\db\models\sql\compiler.py", line 998, in prepare_value
    value = field.get_db_prep_save(value, connection=self.connection)
  File "C:\myApp\lib\site-packages\django\db\models\fields\__init__.py", line 770, in get_db_prep_save
    prepared=False)
  File "C:\myApp\lib\site-packages\django\db\models\fields\__init__.py", line 1301, in get_db_prep_value
    value = self.get_prep_value(value)
  File "C:\myApp\lib\site-packages\django\db\models\fields\__init__.py", line 1296, in get_prep_value
    return self.to_python(value)
  File "C:\myApp\lib\site-packages\django\db\models\fields\__init__.py", line 1258, in to_python
    parsed = parse_date(value)
  File "C:\myApp\lib\site-packages\django\utils\dateparse.py", line 61, in parse_date
    match = date_re.match(value)
TypeError: expected string or bytes-like object

你明白这是怎么回事了吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-06-11 09:19:01

错误信息为:

代码语言:javascript
复制
File "C:\myApp\lib\site-packages\django\utils\dateparse.py", line 61, in parse_date

你的模型中的date有问题:

代码语言:javascript
复制
start_date           = models.DateField(default=False, blank=True, null=True)
end_date             = models.DateField(default=False, blank=True, null=True)

DateField的默认值为date或string not False(bool类型),因此将其更改为:

代码语言:javascript
复制
from django.utils import timezone

start_date           = models.DateField(default=timezone.now, blank=True, null=True)
end_date             = models.DateField(default=timezone.now, blank=True, null=True)

或禁用默认设置,如:

代码语言:javascript
复制
start_date           = models.DateField(blank=True, null=True)
end_date             = models.DateField(blank=True, null=True)

然后进行移民和迁移

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50789320

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档