我正在构建一个 RSS 提要阅读器,用户可以在其中添加自己的提要和类别。我想将所有提要的内容存储在 db 中并运行一个脚本,该脚本将定期为 db 中存在的所有 feed_url 获取该内容(我有一个工作项目,其中每个提要都是实时获取的,这不是一个好主意)
现在经过几次尝试,我进入了以下模型结构。
class Category(models.Model):
name = models.CharField(unique=False, max_length=64)
user = models.ForeignKey(User)
def __unicode__(self):
return self.name
class Meta:
ordering = ('name',)
class Feed(models.Model):
feed_url = models.URLField(unique=True)
def __unicode__(self):
return self.feed_url
class UserFeed(models.Model):
feed = models.ForeignKey(Feed)
title = models.CharField(max_length=256)
category = models.ForeignKey(Category)
user = models.ForeignKey(User)
def __unicode__(self):
return self.title
class Post(models.Model):
feed = models.ForeignKey(Feed, related_name='feed_posts')
## starting from here, my cronjob / script populates the data (using feedparser lib)
title = models.CharField(max_length=256)
content = models.TextField()
link = models.URLField(max_length=512)
dt_published = models.DateTimeField()
dt_cached = models.DateTimeField(auto_now_add=True)
def __unicode__(self):
return '%s (%s)' % (self.feed, self.title)
class Meta:
ordering = ('-dt_published',)
我现在正在寻找的是能够拉入视图并稍后拉入模板,以下实体:
-> 类别 -> 提要 -> 帖子
在我以前的版本中,Feed 和 UserFeed 字段存储在一个表/模型中,我有这样的视图:
def category(request, category_id):
user = request.user
page_title = "Category: "
category = get_object_or_404(Category.objects.filter(id=category_id, user=user)).feed_set.all()
category_name = Category.objects.get(id=category_id)
context = {
'page_title': page_title,
'category': category,
'category_name': category_name,
}
return expand_context_and_render(request, context, 'reader/category.html')
这是我的模板:
{% for feed in category %}
<p><a href="/reader/feed/{{ feed.id }} ">{{ feed.title }}</a></p>
{% for post in feed.post_set.all|slice:"6" %}
<p><a href="{{ post.link }}">{{ post.title }}</a></p>
<p>{{ post.content }}</p>
<p>{{ post.dt_published|timesince }} ago.</p>
{% endfor %}
{% endfor %}
它按预期工作。
现在,由于我不想在我的数据库中有多个 feed_url 副本,我认为新模型还可以,但我根本不知道如何查询和显示这个具有上游和下游关系的新结构。我正在查看 select_related 但没有让它工作。能否请你帮忙 ?