【发布时间】:2019-05-20 13:10:25
【问题描述】:
我正在构建一个简单的黑客新闻网站,希望获得有关如何为提交的帖子集成排名算法的帮助。
我知道我可以通过“order_by”对提交的帖子进行排名,我现在已经这样做了:
def index(request):
submitted_items = Submission.objects.all().order_by('-votecount')[:20]
但是,我想通过考虑提交日期来使排名更加智能。
为了提供更多背景信息,我使用了我发现的教程中的这个代码块作为尝试弄清楚如何实现这种算法的基础:
class HomeView(TemplateView):
template_name = 'home.html'
def get_context_data(self, **kwargs):
ctx = super(HomeView, self).get_context_data(**kwargs)
now = timezone.now()
submissions = Link.objects.all()
for submission in submissions:
num_votes = submission.upvotes.count()
num_comments = submission.comment_set.count()
date_diff = now - submission.submitted_on
number_of_days_since_submission = date_diff.days
submission.rank = num_votes + num_comments - number_of_days_since_submission
sorted_submissions = sorted(submissions, key=lambda x: x.rank, reverse=True)
ctx['submissions'] = sorted_submissions
return ctx
但我无法让它在我自己的应用程序中工作。
我想另一种表达我的问题的方式是这样。 Django/Python 有一个标准的 order_by() 函数,它允许我对数据进行排序,最简单的是按升序或降序排列。有没有办法创建我自己可以使用的独特的自定义 order_by() 函数?
提前感谢您的帮助!
【问题讨论】:
标签: python django python-3.x django-models django-views