【Django问题解决】‘python manager.py inspectdb'命令问题解决

文章目录

      • 报错信息
      • 版本试错
      • 问题分析
      • 总结

报错信息

AttributeError: 'cx_Oracle.Cursor' object has no attribute 'numbersAsStrings'

然后安装低版本的cxOracle==5.2,6.*的时候又包clang的问题。

根据以往的经验直觉,出现这样的问题绝对不是包的问题,也不是主机环境的问题。

可以确定的是Python + Django + cxOracle 这三者之间出现版本匹配的问题。

版本试错

使用pyenv装了python 2.7.14, Python 3.7.1.

Python2的情况下:

  • Django 2.1 + cxOracle 5、6、7 报错
  • Django 1.1 + cxOracle 5、6、7 报错

Python3的情况下:

  • Django 2.1 + cxOracle 5、6、7 报错
  • Django 1.1 + cxOracle 5、6、7 报错

这就奇怪了!!!

由于版本的版本问题,本人更倾向于使用Python3,毕竟大势所趋,所以最后还是使用Python3的解释器。

吃了晚饭回来,继续尝试。

问题分析

  • Django 2.1 + cxOracle 5、6、7 报错
  • Django 1.1 + cxOracle 5、6、7 报错
    都报错,说明不是Python版本的问题, 可以继续使用Python3。

由于查过官网,知道Django2.1是不支持 Oracle12g的(自己的是11g),所以不能再安装Django 2.*了。

于是使用命令: pip install django== 看看Django 1.11的小版本号有哪些。

Collecting django==
  Could not find a version that satisfies the requirement django== (from versions:
   1.1.3, 1.1.4, 1.2, 1.2.1, 1.2.2, 1.2.3, 1.2.4, 1.2.5, 1.2.6, 1.2.7, 1.3, 1.3.1, 1.3.2, 1.3.3, 1.3.4, 1.3.5, 1.3.6, 1.3.7, 1.4, 1.4.1, 1.4.2, 1.4.3, 1.4.4, 1.4.5, 1.4.6, 1.4.7, 1.4.8, 1.4.9, 1.4.10, 1.4.11, 1.4.12, 1.4.13, 1.4.14, 1.4.15, 1.4.16, 1.4.17, 1.4.18, 1.4.19, 1.4.20, 1.4.21, 1.4.22, 1.5, 1.5.1, 1.5.2, 1.5.3, 1.5.4, 1.5.5, 1.5.6, 1.5.7, 1.5.8, 1.5.9, 1.5.10, 1.5.11, 1.5.12, 1.6, 1.6.1, 1.6.2, 1.6.3, 1.6.4, 1.6.5, 1.6.6, 1.6.7, 1.6.8, 1.6.9, 1.6.10, 1.6.11, 1.7, 1.7.1, 1.7.2, 1.7.3, 1.7.4, 1.7.5, 1.7.6, 1.7.7, 1.7.8, 1.7.9, 1.7.10, 1.7.11, 1.8a1, 1.8b1, 1.8b2, 1.8rc1, 1.8, 1.8.1, 1.8.2, 1.8.3, 1.8.4, 1.8.5, 1.8.6, 1.8.7, 1.8.8, 1.8.9, 1.8.10, 1.8.11, 1.8.12, 1.8.13, 1.8.14, 1.8.15, 1.8.16, 1.8.17, 1.8.18, 1.8.19, 1.9a1, 1.9b1, 1.9rc1, 1.9rc2, 1.9, 1.9.1, 1.9.2, 1.9.3, 1.9.4, 1.9.5, 1.9.6, 1.9.7, 1.9.8, 1.9.9, 1.9.10, 1.9.11, 1.9.12, 1.9.13, 1.10a1, 1.10b1, 1.10rc1, 1.10, 1.10.1, 1.10.2, 1.10.3, 1.10.4, 1.10.5, 1.10.6, 1.10.7, 1.10.8, 1.11a1, 1.11b1, 1.11rc1, 1.11, 1.11.1, 1.11.2, 1.11.3, 1.11.4, 1.11.5, 1.11.6, 1.11.7, 1.11.8, 1.11.9, 1.11.10, 1.11.11, 1.11.12, 1.11.13, 1.11.14, 1.11.15, 1.11.16, 1.11.17, 1.11.18, 1.11.20, 2.0a1, 2.0b1, 2.0rc1, 2.0, 2.0.1, 2.0.2, 2.0.3, 2.0.4, 2.0.5, 2.0.6, 2.0.7, 2.0.8, 2.0.9, 2.0.10, 2.0.12, 2.0.13, 2.1a1, 2.1b1, 2.1rc1, 2.1, 2.1.1, 2.1.2, 2.1.3, 2.1.4, 2.1.5, 2.1.7, 2.2a1, 2.2b1)

根据经验,不能太新,不能过旧,由于Django 1.11 是LTS版本,所以想了下,选择了 Django 1.11.18。
执行命令: pip install django==1.11.18 ,然后 python manager.py inspectdb.

出现一下:

# This is an auto-generated Django model module.
# You'll have to do the following manually to clean this up:
#   * Rearrange models' order
#   * Make sure each model has one field with primary_key=True
#   * Make sure each ForeignKey has `on_delete` set to the desired behavior.
#   * Remove `managed = False` lines if you wish to allow Django to create, modify, and delete the table
# Feel free to rename the models, but don't rename db_table values or field names.
from __future__ import unicode_literals

from django.db import models

OK,成了。

总结

由于以前开发使用的是Python2,2019开始使用Python3,第一次开始尝试到了工具版本切换带来的挑战。
不难想象,以后类似的问题还是会有的。

关键还是要耐心看报错,细心看报错,遇到问题不要第一时间copy报错就查,先自己分析问题所在,然后再去网上查;如果什么苗头都不知道,就copy报错一通查,运气好可以碰到解决方案,运气不好,查的越多,人反而越急躁。

因此,沉着耐心分析问题是第一。

你可能感兴趣的:(Django)