Django查询返回空字符串

时间:2016-04-01 14:34:24

标签: python mysql django apache mod-wsgi

我的django应用程序有问题,我创建了两个Blog对象,一个在mysql中,另一个在我的视图中。我在我的数据库中看到了它们,但是当我通过查询得到它们时,我看不到它们。

我正在使用django 1.9,python 2.7,apache 2.2和mod_wsgi

这是我的观点和模板。

def list_view(request):
    blogs = Blog.objects.filter(published=True)

return render_to_response('blog/list.html',
    {
        "blogs": blogs,
    },
    context_instance=RequestContext(request))


{% for blog in blogs %}
    <h2>{{blog.title}}</h2>
    <p>{{blog.content}}</p>
    <span>{% trans 'Writen by' %} : {{blog.writer.last_name}} {{blog.writer.first_name}}</span> - <span>{% trans 'Published on' %} {{blog.date_published}}</span>
{% endfor %}

查询为我提供了一个包含2个Blog对象的列表,但它们都是空的。我的模板只显示了Writen By - 两次发布。

但我可以登录并打印我的所有用户信息。

知道可能是什么问题或者我如何解决它?非常感谢!

编辑:添加models.py

class Blog(models.Model):
    title = models.CharField(_("Title"), max_length=255,   null=False, blank=False)
    content = models.TextField(_("Content"), null=True, blank=True)

    writer = models.ForeignKey(User, verbose_name=_('Writer'), blank=False, null=False)

    published = models.BooleanField(_("Pusblished"), default=False)
    date_published = models.DateTimeField(_("Date published"))

    def __str__(self):
        return '%s' % (self.title)

    def __init__(self, *args, **kwargs):
        super(Blog, self).__init__()

1 个答案:

答案 0 :(得分:3)

当您覆盖Blog.__init__()时,您未向父母发送*args**kwargs。 Django Model magic需要这些参数。如果你在__init__()中没有做任何事情,你可以将它们全部删除。

如果你想保留它,请执行以下操作:

def __init__(self, *args, **kwargs):
    super(Blog, self).__init__(*args, **kwargs)