问题
-
平时在生成migrate文件时,如果出现问题,一般都会显示失败的原因,造成失败的是哪个字段,但是也有可能会出现这种情况:
File "/venv/lib/python3.5/site-packages/django/db/migrations/operations/fields.py", line 148, in state_forwards delay = not old_field.is_relation AttributeError: 'NoneType' object has no attribute 'is_relation'
- 这样仅仅看报错的信息就没办法准确的定位自己失败的原因了。
解决方法
- 修改文件
环境路径 + /lib/python3.5/site-packages/django/db/migrations/operations/fields.py
。
-
打开文件,根据报错提示,找到第148行,在
state_forwards
方法中加入以下代码:print(app_label + " " + self.model_name_lower + " " + self.name)
- 再次执行makemigrations。就会打印出执行时makemigrations走到了哪一个字段。
- 然后就可以根据报错前打印的字段名,定位到问题字段,这样就可以更快的查到错误原因了。