最基础的就不说了,都用utf-8
但是还是有问题
import sys
reload(sys)
sys.setdefaultencoding('utf8')
你需要上面3行代码,加进settings.py
------------------------------------------------------------------------------------------------------------------------------------
喜欢继续了解的可以看这里:
Python里面的编码和解码也就是unicode和str这两种形式的相互转化。编码是unicode->str
相反的解码就是str->unicode。剩下的问题就是确定何时需要进行编码或者解码了
注意以下代码:
#! /usr/bin/env python
# -*- coding: utf-8 -*-
s = '中文' # 注意这里的 str 是 str 类型的,而不是 unicode
s.encode('gb18030')
这句代码将s重新编码成gb18030的格式,即进行unicode->str的转换。应为s本省就是str类型的,
因此Python会自动的先将s解码为unicode,然后再编码成gb18030。因为解码是Pyhon自动进行的,
我们没有指明解码方式,Python就会使用sys.getdefaultencoding()指明的方式来解码。
很多情况下它是ASCII
水印真是烦
如果s不是这个类型就会出错,上面
defaultencoding是ascii,而s的编码方式和文件的编码方式一致,是utf8的,所以出错了
UnicodeDecodeError: 'ascii' codec can't decode byte 0xe4 in position
对于这种情况,有两种解决方法一种是开头说的万能法,第二种就是精密修改
#! /usr/bin/env python
# -*- coding: utf-8 -*-
s = '中文'
s.decode('utf-8').encode('gb18030')