问题

  • 平时在生成migrate文件时,如果出现问题,一般都会显示失败的原因,造成失败的是哪个字段,但是也有可能会出现这种情况:
1
2
3
  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
    tututu
  • 打开文件,根据报错提示,找到第148行,在state_forwards方法中加入以下代码:
1
print(app_label + " " + self.model_name_lower + " " + self.name)
  • 再次执行makemigrations。就会打印出执行时makemigrations走到了哪一个字段。
  • 然后就可以根据报错前打印的字段名,定位到问题字段,这样就可以更快的查到错误原因了。