KeyError:u'editable'在第一次执行./manage.py迁移时

时间:2017-04-26 06:34:52

标签: python django

我最近从Django 1.3升级到1.8,并且在尝试设置迁移时遇到了问题。以前使用South并通过settings.py将其卸载并删除了每个应用程序中的文件夹。

尝试设置迁移时出现此错误:

root@ip:/home/# python manage.py migrate
Operations to perform:
  Synchronize unmigrated apps: web_forms, staticfiles, tinymce, messages, miscellaneous, generalpagess, gallery, template, import, navigation, frontpage, association
  Apply all migrations: admin, contenttypes, sites, auth, sessions
Synchronizing apps without migrations:
  Creating tables...
    Running deferred SQL...
  Installing custom SQL...
Running migrations:
  Rendering model states...Traceback (most recent call last):
  File "manage.py", line 10, in <module>
    execute_from_command_line(sys.argv)
  File "/usr/lib/python2.7/dist-packages/django/core/management/__init__.py", line 354, in execute_from_command_line
    utility.execute()
  File "/usr/lib/python2.7/dist-packages/django/core/management/__init__.py", line 346, in execute
    self.fetch_command(subcommand).run_from_argv(self.argv)
  File "/usr/lib/python2.7/dist-packages/django/core/management/base.py", line 394, in run_from_argv
    self.execute(*args, **cmd_options)
  File "/usr/lib/python2.7/dist-packages/django/core/management/base.py", line 445, in execute
    output = self.handle(*args, **options)
  File "/usr/lib/python2.7/dist-packages/django/core/management/commands/migrate.py", line 222, in handle
    executor.migrate(targets, plan, fake=fake, fake_initial=fake_initial)
  File "/usr/lib/python2.7/dist-packages/django/db/migrations/executor.py", line 100, in migrate
    state.apps  # Render all real_apps -- performance critical
  File "/usr/lib/python2.7/dist-packages/django/utils/functional.py", line 59, in __get__
    res = instance.__dict__[self.name] = self.func(instance)
  File "/usr/lib/python2.7/dist-packages/django/db/migrations/state.py", line 166, in apps
    return StateApps(self.real_apps, self.models)
  File "/usr/lib/python2.7/dist-packages/django/db/migrations/state.py", line 226, in __init__
    self.real_models.append(ModelState.from_model(model, exclude_rels=True))
  File "/usr/lib/python2.7/dist-packages/django/db/migrations/state.py", line 345, in from_model
    name, path, args, kwargs = field.deconstruct()
  File "/usr/lib/python2.7/dist-packages/django/db/models/fields/__init__.py", line 1253, in deconstruct
    del kwargs['editable']
KeyError: u'editable'

运行makemigrations

时,我也遇到了同样的错误
root@:/home/# python manage.py makemigrations
Traceback (most recent call last):
  File "manage.py", line 10, in <module>
    execute_from_command_line(sys.argv)
  File "/usr/lib/python2.7/dist-packages/django/core/management/__init__.py", line 354, in execute_from_command_line
    utility.execute()
  File "/usr/lib/python2.7/dist-packages/django/core/management/__init__.py", line 346, in execute
    self.fetch_command(subcommand).run_from_argv(self.argv)
  File "/usr/lib/python2.7/dist-packages/django/core/management/base.py", line 394, in run_from_argv
    self.execute(*args, **cmd_options)
  File "/usr/lib/python2.7/dist-packages/django/core/management/base.py", line 445, in execute
    output = self.handle(*args, **options)
  File "/usr/lib/python2.7/dist-packages/django/core/management/commands/makemigrations.py", line 99, in handle
    ProjectState.from_apps(apps),
  File "/usr/lib/python2.7/dist-packages/django/db/migrations/state.py", line 178, in from_apps
    model_state = ModelState.from_model(model)
  File "/usr/lib/python2.7/dist-packages/django/db/migrations/state.py", line 345, in from_model
    name, path, args, kwargs = field.deconstruct()
  File "/usr/lib/python2.7/dist-packages/django/db/models/fields/__init__.py", line 1253, in deconstruct
    del kwargs['editable']
KeyError: u'editable'

一直在爬网试图找到解决方案,但没有骰子。

2 个答案:

答案 0 :(得分:1)

当我有一个具有DatetimeField的模型时,我遇到了类似的问题。该模型类似于贝娄

class MyModel(models.Model):
    time = models.DatetimeField(auto_now_add=True)
    time.editable = True

删除最后一行time.editable = True允许我在之后运行python manage.py makemigrations appname命令。

答案 1 :(得分:0)

我终于找到了这个问题。它从阅读这个文件中找到了

File "/usr/lib/python2.7/dist-packages/django/db/models/fields/__init__.py", line 1253`

其中说

def deconstruct(self):
    name, path, args, kwargs = super(DateField, self).deconstruct()
    if self.auto_now:
        kwargs['auto_now'] = True
    if self.auto_now_add:
        kwargs['auto_now_add'] = True
    if self.auto_now or self.auto_now_add:
        del kwargs['editable']
        del kwargs['blank']
    return name, path, args, kwargs

我的代码有auto_now_add=True的时间字段,从我可以收集到的内容来看,从这里的脖子上留下的故事很糟糕:Django auto_now and auto_now_add

del kwargs['editable']部分引发了错误。

相关问题