我在使用MySQLdb运行查询时遇到问题。我有以下错误信息
': 'utf-8' codec can't decode byte 0x92 in position 2: invalid start byte
我过去能够运行此查询而没有编码问题,因此我不知道问题出在哪里。我所做的唯一更改是在笔记本电脑上下载了Postgres,并删除了(偶然地)db.sqlite3文件。但是我不明白为什么这会影响查询的编码,特别是因为我没有任何特殊字符。运行更简单的查询可以正常工作,并且从我的同事笔记本电脑运行此查询也可以。
查询如下:
SLEEPERS_QUERY = """
select * from candidates"""
import MySQLdb as db
with SSHTunnelForwarder(
ssh_address_or_host = host,
ssh_port = 22,
ssh_username = ssh_username,
ssh_pkey = ssh_private_key,
remote_bind_address = (rds, 3306), # 3306 = mysql port
) as server:
server.start()
print('Connected to the SSH server')
while True:
try:
conn = db.connect(
host = localhost,
port = server.local_bind_port,
user = user,
passwd = password,
db = database
)
print('Connected to the database server')
break
except: pass
df = pd.read_sql_query(query,conn)
return df
我找到了解决方案:我的默认编码从latin1更改为utf8。
我必须添加 charset = 'latin1'
conn = db.connect(
host = localhost,
port = server.local_bind_port,
user = user,
passwd = password,
db = database,
charset = 'latin1'
)
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句