Mongoengine + Django:渲染时字段出现奇怪错误
我使用的是 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 的依赖。