- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 sqlalchemy 核心来执行基于字符串的查询。我已将连接字符串上的字符集设置为 utf8mb4
,如下所示:
"mysql+mysqldb://{user}:{password}@{host}:{port}/{db}?charset=utf8mb4"
对于一些简单的选择查询(例如,select name from users where id=XXX limit 1
),当结果集有一些 unicode 字符(例如,'
,ì
等),它会出现以下错误:
UnicodeDecodeError:“utf-8”编解码器无法解码位置 11 中的字节 0x9a:起始字节无效
但是错误本身是不可重现的。当我从 python shell 运行相同的查询时,它可以正常工作。但它会在网络请求或后台作业中出错。
我正在使用 Python 3.8 和 sqlalchemy 1.3.24。
我还尝试过使用 create_engine()
将 charset: utf8mb4
明确指定为 connect_args
属性。
底层数据库是 mysql 5.7,所有 unicode 列都有 utf8mb4
明确设置为模式中的字符集。更新:数据库实际上是AWS RDS Aurora MySQL。
感谢对错误或如何可靠地重现错误的任何见解。
最佳答案
MySQL 文档 Connect-Time Error Handling描述了当您使用 MySQL 8.0 客户端库连接到具有 utf8mb4 字符集的 MySQL 5.7 服务器时 MySQL 8.0 客户端库中的错误。 MySQL 8.0 客户端请求 utf8mb4_0900_ai_ci 排序规则,但 MySQL 5.7 服务器无法识别该排序规则,因此服务器静默回退到带有 latin1_swedish_ci 排序规则的 latin1 字符集。随后服务器发送 latin1 结果集,但客户端认为它正在接收 utf8mb4,最终导致 UnicodeDecodeError
。作为解决方法,您必须显式地 SET NAMES utf8mb4
。我创建了一个问题 mysqlclient#504要求 python 客户端每次都这样做。
要确认连接后字符集不正确,请仔细检查服务器的 character_set_client
值(解释语句的字符集),character_set_connection
(语句转换成的字符集)和 character_set_results
(结果集作为发送的字符集)。如果它们是 latin1
,尽管您尝试使用 utf8mb4 进行连接,则可能已触发此错误。
with con.cursor() as c:
c.execute("show variables like 'character_set_%'")
for row in c:
print(row)
(b'character_set_client', b'latin1')
(b'character_set_connection', b'latin1')
(b'character_set_database', b'latin1')
(b'character_set_filesystem', b'binary')
(b'character_set_results', b'latin1')
(b'character_set_server', b'latin1')
(b'character_set_system', b'utf8')
(b'character_sets_dir', b'/usr/share/mysql/charsets/')
我认为该问题的解决方法是在连接后执行以下操作:
# explicitly set connection charset to the same as MySQLdb.connect()
con.query("SET NAMES utf8mb4")
con.store_result()
关于python - sqlalchemy connection.execute() 上的 UnicodeDecodeError 用于选择查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67680277/
我有一个文本文件,发布者(美国证券交易委员会)声称该文件以 UTF-8 编码(https://www.sec.gov/files/aqfs.pdf,第 4 节)。我正在使用以下代码处理这些行: def
在 django 界面中添加元素时遇到问题。我有两个定义: # -*- coding: utf-8 -*- class VisitType(models.Model): name=models
我尝试制作一个脚本来使用 Mechanize 发布表单 剧本: # Browser br = mechanize.Browser() cj = cookielib.LWPCookieJar() br.
我收到此错误: UnicodeDecodeError: 'ascii' codec can't decode byte 0xe0 in position 4: ordinal not in range
我正在尝试使用 Google 语音 API 在 Python 中制作语音识别器。我一直在使用和改编 here 中的代码(转换为Python3)。我在计算机上使用一个音频文件,该文件已使用在线转换器从
打开一个docker实例(例如docker run -ti ubuntu:16.04),创建Python文件a.py # -*- coding: utf-8 -*- a = 'ö' 和r.py wit
当我将应用程序与Buildozer for Android打包在一起时,我会收到UnicodeDecodeError。 Log2与Buildozer一起附加 build.py 。 作业系统:UBUNT
我在 Ubuntu 终端(编码设置为 utf-8)中运行此代码段两次,一次使用 ./test.py然后用 ./test.py >out.txt : uni = u"\u001A\u0BC3\u1451
我正在尝试使用 Python 中的以下命令序列替换 Word 文件中的子字符串。代码本身工作得很好 - 即使使用完全相同的 Word 文件,但当将其嵌入到更大规模的项目结构中时,它会在确切的位置抛出错
我在 tox 中有以下配置: [tox] envlist = py37 [testenv] passenv = TRAVIS TRAVIS_* setenv = DEFAULT_FROM =
我正在获取 UnicodeDecodeError: 'ascii' codec can't decode byte 0xb0 in position 104: ordinal not in range
在执行子字符串匹配时,我收到 UnicodeDecodeError: 'ascii' codec can't Decode byte 0xc3 inposition 8: ordinal not in
我正在使用 Python 和 lxml,但遇到错误 我的代码 >>>import urllib >>>from lxml import html >>>response = urllib.urlope
我是 python 的新手,我正在尝试处理一小部分 Yelp!数据集是 JSON,但我使用 pandas 库和 NLTK 转换为 CSV。 在对数据进行预处理时,我首先尝试删除所有标点符号以及最常见的
我想不出如何一劳永逸地解决这些问题。当我尝试写“è”(我是意大利人)时,我第一次遇到这些问题。经过一些研究,我发现在最开始添加“#coding: utf-8”似乎可以解决问题....直到现在。 我编辑
我的数据存储包含值,我希望我的表单能够更新这些值。我在 jinja2 中使用 wtforms 和谷歌应用引擎。我收到一条我无法理解的错误消息: 'ascii' codec can't decode b
我们遇到了一个问题(描述为 http://wiki.python.org/moin/UnicodeDecodeError)——请阅读第二段“...自相矛盾...”。 具体来说,我们正在尝试将字符串向上
我正在尝试标记一些文档,但我遇到了这个错误 UnicodeDecodeError: 'ascii' codec can't decode byte 0xef in position 6: ordina
我想在一个文件中存储一个包含多个 numpy 数组的 Python 对象。我找到了 pickle,但在加载存储的对象时总是遇到 UnicodeDecodeError: Traceback (mos
我正在尝试制作一个 python 脚本来查找 USB 闪存驱动器中的重复文件。 我遵循的过程是创建一个文件名列表,散列每个文件,然后创建一个逆向字典。然而,在过程中的某个地方,我得到了一个 Unico
我是一名优秀的程序员,十分优秀!