天天看点

'NoneType' object has no attribute 'is_relation',报错原因定位

问题

  • 平时在生成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

    'NoneType' object has no attribute 'is_relation',报错原因定位
  • 打开文件,根据报错提示,找到第148行,在

    state_forwards

    方法中加入以下代码:
    print(app_label + " " + self.model_name_lower + " " + self.name)           
  • 再次执行makemigrations。就会打印出执行时makemigrations走到了哪一个字段。
  • 然后就可以根据报错前打印的字段名,定位到问题字段,这样就可以更快的查到错误原因了。

参考链接:

Django makemigrations 报错原因定位