Mongoengine + Django:渲染过程中字段的奇怪错误

时间:2014-09-03 21:39:17

标签: python django mongodb mongoengine

我使用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'(字段文本),结果:

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查询现有的集合以在Web界面中显示推文。我不想在ORM中定义所有推文结构。

我有Robomongo,我看到手动添加的推文附近的管理帖子,由Twitter python库挖掘。字段被命名为“text”和“lang”,因为在推文JSON中它们的名称相同。 为什么其他领域不起作用?

1 个答案:

答案 0 :(得分:1)

找到自己答案:

在views.py中我将tweets = Post.objects更改为tweets = Tweet.objects - 这是使用没有我需要查询的字段的上层模型的主要错误

然后我将集合重命名为tweets - 现在我的查询有效,而没有_cls依赖