2013-07-30 251 views
1

简单,真的。 使用MySQL后端,我试图挽救一个模型实例从Django管理命名为“门徒新”。 但我得到了可怕的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

谢谢!

P.S.运行生成的SQL直接工作得很好

+0

您是否在该模型中定义了__str__或__unicode__?你覆盖'save()'吗? – Private

+0

是的,我定义了'__unicode__'。 –

+0

谢谢,私人。就是这样。 –

回答

2

这往往是在__unicode__定义一个probem。确保在模型类中定义了一个__unicode__方法,并确保它返回一个unicode字符串。

+0

谢谢你。我会包括其他的例子: –

+0

'高清__unicode __(个体经营): 回报 “%S-%的” %(UNICODE(self.foo),统一(self.bar))' –

+0

我想你也可以直接做'返回你'%s-%s“%self.foo,self.bar',其中'u'表示你正在使用unicode字符串。 – Private

3

我有同样的问题在某些机型 - 基本上在我忘了正确重写方法的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,因为这并不能保证返回unicoded字符串。

这里有一个完整的例子:

# -*- 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) 

希望它能帮助!

此致敬礼迈克尔