很简单真的。使用MySQL后端,我试图从Django管理器中保存一个名为"Protégé“的模型实例。但我得到了令人生畏的unicode错误:
UnicodeDecodeError at /admin/foo/bar/226/
'ascii' codec can't decode byte 0xc3 in position 4: ordinal not in range(128)有没有办法在不扩展管理的情况下修复这个问题?表是DEFAULT CHARSET=utf8。
谢谢!
直接运行生成的SQL很好
发布于 2013-07-31 06:55:24
这通常是__unicode__定义中的一个问题。确保在模型类中定义了__unicode__方法,并确保它返回unicode字符串。
发布于 2013-12-16 11:27:08
在某些模型中,我也遇到了同样的问题--基本上在所有模型中,我都忘记正确地覆盖unicode方法。在我的例子中,我首先在Windows机器上运行后端,这很好,但是当我在Linux机器上发布后端时,我在编辑模型时也遇到了同样的错误。我就是这样修好的。首先,模型类以# -*- coding: UTF-8 -*-开始(在第一行!)。在模型中,我重写__unicode__并返回一个unicode字符串。
这可以通过返回unicode(self.name)或如何使用u'%s' %(self.name)或u'Name: %s, Value: %s' %(self.name, self.value)来完成。
如果您使用return self.name,它将无法工作,因为这并不能确保返回独角形字符串。
下面是一个完整的例子:
# -*- coding: UTF-8 -*-
import ... # all imports etc. after the coding: UTF-8 line!
class ModelName(models.Model):
name = models.CharField(max_length=20)
def __unicode__(self):
return u'%s' %(self.name)希望能帮上忙!
向你问好,迈克尔
https://stackoverflow.com/questions/17949985
复制相似问题