如何添加__unicode__来显示sqlite3信息性数据库信息?

时间:2013-10-31 15:59:16

标签: python django unicode

首先我要提到没有Traceback。它只是没有做它应该做的事情。

这两个类定义了应用程序的数据模型。

from django.db import models
import datetime

class Poll(models.Model):
    question = models.CharField(max_length=200)
    pub_date = models.DateTimeField('date published')
    def __unicode__(self):  # Python 3: def __str__(self):
        return self.question
    def was_published_recently(self):
        return self.pub_date.date() == datetime.date.today()

class Choice(models.Model):
    poll = models.ForeignKey(Poll)
    choice_text = models.CharField(max_length=200)
    votes = models.IntegerField(default=0)
    def __unicode__(self):  # Python 3: def __str__(self):
        return self.choice_text

在这里添加unicode代码:

def __unicode__(self):
    return self.question

假设让Django API调用返回有关对象的更多信息。这是API调用:

# objects.all() displays all the polls in the database. 
>>> Poll.objects.all()

这是 Poll.objects.all()的非信息性回报:

>>> Poll.objects.all()
[<Poll: Poll object>]

在添加unicode方法之后它应该显示的信息量更大的答案应该是这样的:

>>> Poll.objects.all()
[<Poll: What's up?>] 

我遇到的问题/错误是它仍然显示非信息性答案。

1 个答案:

答案 0 :(得分:0)

如果您遇到此问题,您在课程中添加了一些内容,并且在运行API命令时没有显示。您可以尝试以下方法。

  1. 重新开始翻译。
  2. 关闭机器并继续打开。
  3. 可能会再次返回并同步数据库。
  4. 我不知道这些工作中的哪一项是因为我曾经在所有这些方面做过。但它现在肯定有效。所以代码缩进或其他任何东西都没有错。

    下面的补充答案:

    我在Django教程中找到了这个。这可能是解决这个问题的最正确答案:

    您需要重新启动开发服务器才能查看更改。通常,服务器会在每次修改文件时自动重新加载代码,但创建新文件的操作不会触发自动重新加载逻辑。