我的编程空间,编程开发者的网络收藏夹
学习永远不晚

pymysql KeyError:25

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

pymysql KeyError:25

在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 <module>
    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://<USERNAME>:<PASSWD>@<HOSTNAME>:<PORT>/<DBNAME>')

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

Traceback (most recent call last):
  ...
  File "C:\Program Files\Python36\lib\site-packages\pymysql\__init__.py", line 90, in Connect
    return Connection(*args, **kwargs)
  File "C:\Program Files\Python36\lib\site-packages\pymysql\connections.py", line 706, in __init__
    self.connect()
  File "C:\Program Files\Python36\lib\site-packages\pymysql\connections.py", line 931, in connect
    self._get_server_information()
  File "C:\Program Files\Python36\lib\site-packages\pymysql\connections.py", line 1269, in _get_server_information
    self.server_charset = charset_by_id(lang).name
  File "C:\Program Files\Python36\lib\site-packages\pymysql\charset.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...

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

pymysql KeyError:25

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

pymysql KeyError:25

在weibospider项目新建所有的表时遇到的错误:Traceback (most recent call last): File "/Library/Frameworks/Python.framework/Versions/3.6/l
2023-01-31

pymysql

python代码连接mysql数据库有bug(sql注入的问题):#pip3 install pymysqlimport pymysqluser=input("user>>: ").strip()pwd=input("password>>: ").strip(
pymysql
2020-06-10

python-pymysql

1.基本用法import pymysql#建立连接conn=pymysql.connect( host='localhost', port=3306, user='root', password='123456',
2023-01-31

元类, pymysql

元类, pymysql一、元类自定义元类'''1、什么是元类? - 类的类就是type,其实type就是元类2、元类的作用?3、如何创建元类以及使用?'''# # 1、一切皆对象# list1 = [] # list1 = list([])# prin
2020-12-26

python3之pymysql

pymsql是Python中操作MySQL的模块并且只有在Python3.0版本中才存在,其使用方法和MySQLdb几乎相同。下载安装pymsql模块pip3 install pymysql操作前准备#1.创建数据库mysql> creat
2023-01-31

这个keyerror是什么问题

KeyError是一个Python中的异常类型,表示请求的键不存在于字典中。当我们以一个不存在的键访问字典中的元素时,就会抛出KeyError异常。例如:```my_dict = {"a": 1, "b": 2}print(my_dict[
2023-08-08

python keyerror错误怎么解决

Python中的KeyError错误通常是由于字典或集合中不存在指定的键而引发的。要解决KeyError错误,可以按照以下步骤进行操作:检查错误的源头:查看报错信息中指定的键和相关代码行,确定哪个字典、集合或其他数据结构中引发了错误。确认键
python keyerror错误怎么解决
2024-02-29

python pymysql存储

1 # _*_ coding:utf-8 _*_ 2 import requests 3 from bs4 import BeautifulSoup 4 import re 5 import pymysql 6 7 def create(
2023-01-30

python安装pymysql

1.通过pip进行安装 pip install pymsql2.验证安装是否成功 python import pymysql pymysql.VERSION
2023-01-31

【Python3】pymysql模块

1. 什么是 PyMySQL?PyMySQL 是在 Python3.x 版本中用于连接 MySQL 服务器的一个库,Python2中则使用mysqldb。PyMySQL 遵循 Python 数据库 API v2.0 规范,并包含了 pure
2023-01-31

python报错KeyError: 231怎么解决

KeyError: 231是Python中的一个错误提示,它表示在字典中没有找到指定的键。要解决这个问题,你可以采取以下步骤:1. 确保你正在访问存在的键:首先,确认你正在尝试访问的键存在于字典中。你可以使用`in`操作符来检查键是否存在,
2023-08-19

python报错KeyError: 231是什么意思

该错误意味着在尝试访问一个字典中不存在的键时发生了错误。具体来说,键"231"在给定的字典中不存在。例如,假设有一个名为"my_dict"的字典,包含以下键值对:```my_dict = {"key1": "value1", "key2":
2023-08-18

Python中keyerror错误怎么解决

KeyError错误在Python中通常发生在尝试访问字典中不存在的键时。解决该错误的方法如下:1. 确保键存在:在访问字典之前,可以使用`in`关键字来检查键是否存在于字典中。例如:```pythonmy_dict = {'key1':
2023-08-08

Python的pymysql用法

使用pip安装pymysql 的方法pip install pymysql连接数据库conn = pymysql.connect(host="127.0.0.1", user="用户名", password="密码", database="数据库名", cha

	Python的pymysql用法
2017-03-03

pymysql模块的使用

pymysql的下载和使用之前我们都是通过MySQL自带的命令行客户端工具mysql来操作数据库,那如何在python程序中操作数据库呢?这就用到了pymysql模块,该模块本质就是一个套接字客户端软件,使用前需要事先安装(1)pymysq
2023-01-30

编程热搜

目录