Jquery中文网 www.jquerycn.cn
Jquery中文网 >  Python编程  >  python进阶  >  正文 python数据库查询中文乱码

python数据库查询中文乱码

发布时间:2021-01-13   编辑:www.jquerycn.cn
jquery中文网为您提供python数据库查询中文乱码等资源,欢迎您收藏本站,我们将为您提供最新的python数据库查询中文乱码资源

解决python数据库查询出现中文乱码的方法:1、python文件设置编码为utf-8;2、MySQL数据库字符集改为“charset=utf8”;3、Python连接MySQL时加上参数"charset=’utf-8"。

执行pip install PyMySQL 完成pyMySQL安装

数据库部分

-- 建表语句

CREATE TABLE books (
  name varchar(50) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

-- 插入数据

insert into books values('万物生光辉');
insert into books values('我亲爱的甜橙树');
insert into books values('教父');
insert into books values('故事');
insert into books values('树上的男爵');
insert into books values('罗马人的故事2');
insert into books values('秘岛(全三册)');

python代码

#!/usr/bin/env python
import pymysql.cursors
connection = pymysql.connect(user='用户名', passwd='密码', db='数据库名')
cursor = connection.cursor()
ex = cursor.execute("select name from books")
books = cursor.fetchmany(ex)
for book in books:
    print("%s" % book[0])
connection.close()

执行结果

1.png

解决乱码方法如下:

Python文件设置编码 utf-8 (文件前面加上 #encoding=utf-8)

MySQL数据库charset=utf-8

Python连接MySQL时加上参数 charset=’utf8’

读取数据后写入文件前执行编码book[0].encode(‘utf-8’)

最后测试的时候发现只需在连接MySQL的时候加上charset=’utf8’即可,以utf-8编码格式读取数据,其他条件无需添加,也不会出现从mysql中读取的数据出现中文乱码的情况。

修改后python代码

#!/usr/bin/env python
import pymysql.cursors
# 在连接Mysql的时候添加charset='utf8'即可解决中文乱码问题
connection = pymysql.connect(user='用户名', passwd='密码', db='数据库名', charset='utf8')
cursor = connection.cursor()
ex = cursor.execute("select name from books")
books = cursor.fetchmany(ex)
for book in books:
    print("%s" % book[0])
connection.close()


修改后的执行结果

2.png

您可能感兴趣的文章:
如何解决php中文字符乱码,中文字符入库乱码的问题
php查询数据库并输出乱码
php pdo编码乱码问题的解决方法
python数据库查询中文乱码
php查询表中文乱码
解决PHP提交MYSQL数据库中文内容乱码方法
查询mysql编码以及解决mysql乱码问题
php乱码怎么解决?
python如何访问数据库
python怎么连接数据库

[关闭]