现在的位置: 首页 > 综合 > 正文

django,模型文件新增中文字段说明报错问题

2018年04月30日 ⁄ 综合 ⁄ 共 1469字 ⁄ 字号 评论关闭
   今天学习django的admin管理功能,据说很好很强大。。
   全都弄好了,发现在管理页面中字段的说明用的是数据库中的字段名也就是说显示的是英文字'name'什么的。觉得不爽,换了他。于是修改模型文件。
class Publisher(models.Model):
    name = models.CharField('出版商',max_length=30)
    address = models.CharField('地址',max_length=50)
    city = models.CharField('城市',max_length=60)
    state_province = models.CharField('省',max_length=30)
    country = models.CharField(国家',max_length=50)
    website=models.URLField(verbose_name='网址')
    def __unicode__(self):
        return self.name 
保存一下,web服务器自动更新,结果当操作页面到显示页的时候报错了。错误是:“utf8' codec can't decode byte 0xb3 in position 0....”,意思的大概是说,在解码的时候,不能正常界面UTF8字符。这可咋整呢。
   Google了一下,大部分都是外文网站,也有几个国内哥们说过类似问题,反正就是说编码问题。不过我也是看的五迷三道的。。。
   于是我找了一下自己博客中记录的关于输出Unicode编码的帖子,在shell中敲了出来
   >>>a='我们'
   >>>a
   >>>'/xce/xd2/xc3/xc7'
   >>>b=a.decode('GB2312') #按着gb2312解码
   >>>b
   >>>u'/u6211/u4eec'
   运行到这里看出点门道,将a('/xce/xd2/xc3/xc7')按着gb2312解码后,变成了Unicode形式,两个字节,会不会我将这个传入上边的函数会解决于是修改代码:
   增加函数对字符串按着“gb2312”进行解码
   def decode(info):
      return info.decode('GB2312')
   class Publisher(models.Model):
       name = models.CharField(decode('出版商'),max_length=30)
       address = models.CharField(decode('地址'),max_length=50)
       city = models.CharField(decode('城市'),max_length=60)
       state_province = models.CharField(decode('省'),max_length=30)
       country = models.CharField(decode('国家'),max_length=50)
       website=models.URLField(verbose_name=decode('网址'))
       def __unicode__(self):
          return self.name 
    保存后运行验证一下
    哈成功了。。。。
   
    中文编码问题会是大家在Python和django中常遇到的问题,这里将自己的解决思路总结下来,一是方便以后查找,另一方面,也希望大家能够借鉴。

抱歉!评论已关闭.