如何解决django:运行 makemigrations / migrate 时不要注册 ModelAdmin排除模块级代码
我对现有的 django 模型进行了多次更改(添加了新的外键关系等)。 在使用 manage.py makemigrations / migrate 创建和应用这些更改之前,我为该应用调整了相应的管理模块的 ModelAdmin 以反映这些未应用的更改。
运行 makemigrations 现在失败,并显示“ProgrammingError: {new_field} 不存在”。我认为这是因为当 makemigrations 运行系统检查时,admin.py 中的 ModelAdmins 已注册(对我尝试使用迁移创建的不存在的模型执行查询)。
问题:在运行 manage.py makemigrations / migrate 而不完全禁用系统检查时,是否有任何直接的方法可以排除 ModelAdmins 的注册(请参阅 Django migration - disabel system checks)?
我可以通过在运行 makemigrations / migrate 时删除我的 admin.py 模块并在之后重新创建它们来解决问题。迁移时确实不需要检查管理模块,但我想这会发生在 admin.py 的模块级别上注册 ModelAdmins 时(如 django admin documentation 中的示例)。我不使用自定义 AdminSite。
更一般的术语:在运行特定的 manage.py 命令(如 makemigrations 或 migrate)时,是否有任何直接的方法可以排除特定的顶级模块代码的执行?
解决方法
我想出了一个合理的方法来做到这一点。
由于我如此拼命地寻找一种 django-native 方法来检查当前命令,所以我没有想到像往常一样简单地评估命令行参数来执行此操作。
从命令行调用 makemigrations 或 migrate 时,我可以使用 sys.argv[1]
获取命令的名称。这应该适用于 django 运行系统检查时自动执行的任何顶级代码。
ModelAdmins 的注册是通过 django.contrib.admin.autodiscover()
引起的,当使用默认的 AdminConfig
时(即当 django.contrib.admin
包含在 INSTALLED_APPS
设置中时)会自动调用它。我们可以在设置中使用 django.contrib.admin.apps.SimpleAdminConfig
,这样 autodiscover()
不会被自动调用(参见 django admin docs)。
我将 settings.py
中的相应部分从
INSTALLED_APPS = [
...
"django.contrib.admin",...
]
到
MIGRATION_COMMAND = sys.argv[1] in ('makemigrations','migrate')
INSTALLED_APPS = [
...
"django.contrib.admin.apps.SimpleAdminConfig" if MIGRATION_COMMAND else "django.contrib.admin",...
]
这样,我的应用程序的所有 admin.py
模块在运行 makemigrations / migrate 时都会被忽略。
如果需要,我现在还可以在其他任何地方使用自定义 MIGRATION_COMMAND
设置。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。