Mongoengine + Django:渲染时字段出现奇怪错误

1 投票
1 回答
526 浏览
提问于 2025-04-19 16:51

我使用的是 Mongoengine 0.8.7 和 Django 1.6.5,还有 Mongodb 2.7。我有一个模型:

class Tweet(DynamicDocument):
#user = ReferenceField(User, reverse_delete_rule=CASCADE)
#id = StringField(db_field='id',required=True)
text = StringField(db_field='text', required=True)
lang = StringField(db_field='lang', max_length=200)
slug = StringField(db_field='slug', max_length=200)
retweeted = BooleanField()
#retweet_count = IntField()
text_length = IntField()
date_modified = DateTimeField(default=datetime.now)
is_published = BooleanField(default=True)
tags = ListField(ReferenceField(Tag))

#meta = {'allow_inheritance': False}

def __unicode__(self):
    return self.text

def save(self, *args, **kwargs):
    self.text_length = len(self.text)
    return super(Post, self).save(*args, **kwargs)

def get_absolute_url(self):
    return reverse('post-detail', args=[self.id])

def get_edit_url(self):
    return reverse('post-update', args=[self.id])

def get_delete_url(self):
    return reverse('post-delete', args=[self.id])

在 views.py 中查看:

class TweetListView(ListView):
    model = Tweet
    context_object_name = "tweet_list"

    def get_template_names(self):
        return ["blog/tweet_list.html"]

    def get_queryset(self):
        tweets = Post.objects
        if 'all_posts' not in self.request.GET:
            tweets = tweets.filter(text__startswith='RT')
        tag = self.request.GET.get('tag', None)
        if tag:
            tweets = tweets.filter(tags=tag)

        #if not tag:
        #    tweets = tweets.filter(retweeted=True)
        return tweets

还有模板:

{% extends "base.html" %}

{% block content %}
    {% for tweet in tweet_list %}
        <div style="margin-bottom: 20px;">
                <h4>tweet.id: {{ tweet.id }}</h4>
            {{ tweet.text|linebreaks }}
                        tweet.retweeted: {{ tweet.retweeted }}
            tweet.created_at: {{ tweet.created_at }}

            {% if tweet.tags %}
            Tags:
            <ul>
                {% for tag in tweet.tags %}
                    <li><a href="?tag={{ tag.id }}">{{ tag }}</a></li>
                {% endfor %}
            </ul>           
               {% endif %}
        </br>
            <a href="{{ tweet.get_absolute_url }}" class="btn btn-small">Read</a>
            <a href="{{ tweet.get_edit_url }}" class="btn btn-small">Edit</a>
            <a href="{{ tweet.get_delete_url }}" class="btn btn-small">Delete</a>
        </div>
    {% endfor %}
{% endblock %}

一切都正常,推文在浏览器中显示出来。当我在视图中使用过滤条件 is_published=True 时没问题,但如果我换成其他条件,就会出现错误。例如,我使用:text__startswith='RT'(字段是 text),结果是:

Exception Value:    

id must be an instance of (str, unicode, ObjectId), not <type 'dict'>

Exception Location:     D:\WinPython-32bit-2.7.5.1\python-2.7.5\lib\site-packages\bson\objectid.py in __validate, line 203

如果我改成 tweets.filter(slug__startswith='RT'),结果是:

Exception Value:    

Cannot resolve field "slug"

Exception Location:     build\bdist.win32\egg\mongoengine\queryset\transform.py in query, line 60

我用外部脚本挖掘了推文,现在想用 Flask 来查询已有的集合,以便在网页界面上显示推文。我不想在 ORM 中定义所有推文的结构。

我有 Robomongo,看到从管理员手动添加的帖子和通过 Twitter 的 Python 库挖掘的推文在一起。字段被命名为 "text" 和 "lang",因为在推文的 JSON 中它们也是这样命名的。为什么其他字段都不工作呢?

1 个回答

1

我自己找到了答案:

在views.py文件中,我把 tweets = Post.objects 改成了 tweets = Tweet.objects - 这是我最大的错误,因为我用了一个不包含我需要查询字段的上层模型。

然后我把集合的名字改成了 tweets - 现在我的查询可以正常工作了,而且没有了 _cls 的依赖。

撰写回答