资讯专栏INFORMATION COLUMN

pymysql KeyError:255

entner / 2574人阅读

摘要:在项目新建所有的表时遇到的错误没有找到出错的具体原因,所以只能更换一个引擎,在这里找到了一个临时方案安装新的引擎使用方法更新导致上述问题的主要原因可能是这个错误主要原因是更新了很多字符集,但是这些字符集长度超过了,所以旧版

在weibospider项目新建所有的表时遇到的错误:

Traceback (most recent call last):
  File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/sqlalchemy/pool.py", line 1122, in _do_get
    return self._pool.get(wait, self._timeout)
  File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/site-packages/sqlalchemy/util/queue.py", line 145, in get
    raise Empty
sqlalchemy.util.queue.Empty

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "create_all.py", line 10, in 
    create_all_table()
  File "create_all.py", line 7, in create_all_table
    metadata.create_all()
  ...

没有找到出错的具体原因,所以只能更换一个引擎,在这里找到了一个临时方案:
安装新的引擎:

 $ pip install mysql-connector-python

使用方法:

 Engine = create_engine("mysql+mysqlconnector://:@:/")

(2018.5.3更新)
导致上述问题的主要原因可能是KeyError: 255这个错误:

Traceback (most recent call last):
  ...
  File "C:Program FilesPython36libsite-packagespymysql\__init__.py", line 90, in Connect
    return Connection(*args, **kwargs)
  File "C:Program FilesPython36libsite-packagespymysqlconnections.py", line 706, in __init__
    self.connect()
  File "C:Program FilesPython36libsite-packagespymysqlconnections.py", line 931, in connect
    self._get_server_information()
  File "C:Program FilesPython36libsite-packagespymysqlconnections.py", line 1269, in _get_server_information
    self.server_charset = charset_by_id(lang).name
  File "C:Program FilesPython36libsite-packagespymysqlcharset.py", line 38, in by_id
    return self._by_id[id]
KeyError: 255

主要原因是MySQL8.0更新了很多字符集,但是这些字符集长度超过255了,所以旧版的PyMySQL不支持长度超过255的字符
查看当前版本的PyMySQL:

> pip list
Package                Version
---------------------- -----------
PyMySQL                0.7.11

更新PyMySQL:

> pip install --upgrade PyMySQL
Collecting PyMySQL
  Downloading https://files.pythonhosted.org/packages/e5/07/c0f249aa0b7b0517b5843eeab689b9ccc6a6bb0536fc9d95e65901e6f2ac/PyMySQL-0.8.0-py2.py3-none-any.whl (83kB)
    100% |████████████████████████████████| 92kB 453kB/s
Installing collected packages: PyMySQL
  Found existing installation: PyMySQL 0.7.11
    Uninstalling PyMySQL-0.7.11:
      Successfully uninstalled PyMySQL-0.7.11
Successfully installed PyMySQL-0.8.0

相关内容:

https://github.com/PyMySQL/Py...

https://github.com/PyMySQL/Py...

https://github.com/PyMySQL/Py...

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/42609.html

相关文章

  • 【Python3】pymysql模块

    摘要:模块什么是是在版本中用于连接服务器的一个库,中则使用。遵循数据库规范,并包含了客户端库。 【Python3】pymysql模块 1. 什么是 PyMySQL? PyMySQL 是在 Python3.x 版本中用于连接 MySQL 服务器的一个库,Python2中则使用mysqldb。 PyMySQL 遵循 Python 数据库 API v2.0 规范,并包含了 pure-Python ...

    Drummor 评论0 收藏0
  • python中操作mysql的pymysql模块详解

    摘要:简述是中操作的模块,其使用方法和几乎相同。但目前支持而后者不支持版本。因此要避免这种情况需使用提供的参数化查询。使用存储过程动态执行防注入使用存储过程自动提供防注入,动态传入到存储过程执行语句。 简述 pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb几乎相同。但目前pymysql支持python3.x而后者不支持3.x版本。本文测试python版本:3.5....

    shiweifu 评论0 收藏0

发表评论

0条评论

entner

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<