django--中文乱码问题

本文探讨了Python中编码与解码的基本原理,重点讲解如何处理Unicode与str之间的转换问题。通过实例演示了如何避免常见的UnicodeDecodeError错误,并提供了解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最基础的就不说了,都用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') 


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值