python从数据库中获取utf8格式的中文数据输出时变成问号或乱码

Posted _从未止步

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python从数据库中获取utf8格式的中文数据输出时变成问号或乱码相关的知识,希望对你有一定的参考价值。

    我用python操作mysql数据库,数据库中数据格式为utf8,我使用python调用select语句后获取到数据库的信息,然后使用print打印出来的时候,原本中文数据却无法显示,显示出来的是一串?,为了解决这个问题,我也是绞尽脑汁啊。

    我在网上搜集了很多资料,大家都说是windows默认的格式是'GBK',输出从mysql数据库中获取到的中文数据时,需要这样写:

假设info是从数据库中获取的中文值
print info.decode('UTF-8').encode('GBK')

结果:


但是,我这样试了很多遍还是没有解决问题,还是输出?,也有人的观点是说在链接数据库的时候传入编码格式

db = MySQLdb.connect('localhost','root','',"zou",3306,'utf8')

结果:

     

这样还是没有达到预期的效果,不过他这次不是出现?,而是变成乱码了,不过到这里的话已经朝着好的方向发展。


最终,我结合上述两种观点,达到了目的^_^

具体操作可以看看我的代码:


这次再看看程序运行的结果:


好的,问题解决!

以上是关于python从数据库中获取utf8格式的中文数据输出时变成问号或乱码的主要内容,如果未能解决你的问题,请参考以下文章

python解析json格式出问题?

jsp表单提交中文插入数据库,数据库出现问号?

使用 python 从 mp3 音频文件中获取幅度数据

从一个非常大的 MySQL 转储文件中以 csv 格式获取数据

Python调用MySQL的一些用法小结

MySQL乱码的原因和设置UTF8数据格式