Python的各类编码设置

以前咱们编写了一个python操做数据库的方法,按照文档的提供的参数来写,写完了之后本身测试发现报了一个编码的错误,也不知道为何会报这个错误,我通常对编码的错误比较在乎,原来搞php的时候,就出现过读取数据库里的信息编码错误,后来我吸收了教训,用php读取数据库数据按照一套标准来走就没有出现过编码的问题。php

个人标准是:设置4个地方编码一致。
1数据库编码
2数据表编码
3程序文件编码
4读取数据以前设置好编码html

我如今用python读取mysql数据库的时候就遇到:数据库错误: 'ascii' codec can't encode characters in position 0-4: ordinal not in range(128)python

我检查了下各处的编码,数据库,数据表和文件的编码都是utf-8,都是一致的,那为何仍是会出现编码的问题呢?
我想应该是读取数据以前没有设置默认的编码,接着我查了下文档,发现了解决办法。mysql

我经过sys模块的setdefaultencoding('编码类型')来进行python 编码设置。sql

下面给出个人代码:
#encoding=utf-8
import sys
import MySQLdb数据库

reload(sys)
sys.setdefaultencoding('utf-8')测试

看来应该先设置好编码类型,再读取数据就不会出错了。编码

还有, Python条件语句的嵌套使用初学者必定要掌握,推荐资料:http://www.iplaypython.com/jinjie/jj172.htmlcode

相关文章
相关标签/搜索