2013-07-30 64 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) 

希望它能幫助!

此致敬禮邁克爾