django mysql\base.py 报错 KeyError: class 'bytes'

这次升级了Python版本到了3.6.
但是django2.2的长期支持版本还没稳,所以使用的是1.11的版本,于是写项目就报错了。
然后使用django的时候,makemigrations的时候报错conn.encoders[SafeBytes] = conn.encoders[bytes] KeyError: <class ‘bytes’>。
追踪源码:
问题文件:Python36\lib\site-packages\django\db\backends\mysql\base.py
def get_new_connection(self, conn_params):
conn = Database.connect(**conn_params)
conn.encoders[SafeText] = conn.encoders[six.text_type]
conn.encoders[SafeBytes] = conn.encoders[bytes]
return conn

问题分析
经过百度,发现没有相似的问题。随机谷歌,找到了相关的两个页面:

Django KeyError <class ‘bytes’> in version 1.4.0rc1 · Issue #306 · PyMySQL/mysqlclient-python
new charset definition added by peakkk · Pull Request #591 · PyMySQL/PyMySQL

所以出问题是因为mysqlclient的版本太新了,用pip3 list命令查看,果然我的mysqlclient 的版本是1.4.1 。
解决方案

给MySQLclient降级。先卸载,再安装指定版本。pip3 uninstall mysqlclient,pip3 install mysqlclient==1.3。
我最开始的解决方案,改django的代码(Python36\lib\site-packages\django \db\backends\mysql\base.py),加一个if:

def get_new_connection(self, conn_params):
    conn = Database.connect(**conn_params)
    conn.encoders[SafeText] = conn.encoders[six.text_type]
    # 先判断bytes是否存在于编码器中,如果在才执行操作
    if bytes in conn.encoders:
        conn.encoders[SafeBytes] = conn.encoders[bytes]
    return conn
  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值